iOS tableView嵌套部分WebView效果实现
对于一些资讯类的app,比如网易新闻,今日头条这样的,他们的文章详情页大部分基本都是tableView中嵌套webView来实现的效果,其中顶部标题,关注按钮等这些可能是原生的,内容部分是webView,评论部分,相关推荐等是原生的,对于这样一样比较复杂的页面,今天这里提供一个类似的demo
demo中顶部图片 顶部标题,活动时间等相关信息都是原生的代码实现下面活动详情是由webView来实现,最底部评论模块一般都是原生来实现
实现这种效果的主要思路就是拿到数据后,去加载webView,等webView加载完毕后,拿到html的高度,去重新设置网页部分的高度
核心实现代码:
-(void)webView:(WKWebView *)webView didFinishNavigation:(WKNavigation *)navigation{
[self.webView evaluateJavaScript:@"document.body.offsetHeight" completionHandler:^(id _Nullable result, NSError * _Nullable error) {
//这里是重点 webView加载完成后需要把webView的高度返回 所有要在这里计算tableView header的总高度
[self.webView mas_updateConstraints:^(MASConstraintMaker *make) {
make.height.mas_equalTo(([result doubleValue]+10));
}];
if (self.headerBlock) {
//这里计算高度,根据实际内容来 每个高度都需要加上的
CGFloat viewHeight = 0.0f;
CGFloat SCREEN_WIDTH = [UIScreen mainScreen].bounds.size.width;
viewHeight = [result doubleValue] + 10 + SCREEN_WIDTH *0.51 + 5 + [self getHeightWithTitle:self.paramDict[@"title"] font:self.titleLabel.font maxWidth:SCREEN_WIDTH -15 - 10] + 160;
self.headerBlock(viewHeight);
}
}];
}
-(void)webView:(WKWebView *)webView didFailNavigation:(WKNavigation *)navigation withError:(NSError *)error{
if (error) {
if (self.headerBlock) {
self.headerBlock(-1);
}
}
}
-(void)loadHtmtString:(NSString *)content{
NSString *htmlcontent = [NSString stringWithFormat:
@"<html>"
"<head>"
"<meta charset='utf-8' name='viewport' content='width=device-width,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no'/>"
"<style type=\"text/css\">"
"img {"
"max-width:100%%;"
// "width:auto;"
// "height:auto;"
"-webkit-tap-highlight-color:rgba(0,0,0,0);"
"}"
"</style>"
"<script type=\"text/javascript\">"
"</script>"
"</head>"
"<body>"
"<div>"
"<div id=\"webview_content_wrapper\">%@</div>"
"</div>"
"</body>"
"</html>"
,content];
[self.webView loadHTMLString:htmlcontent baseURL:nil];
}
解析json数据
//取出json文件
NSData *JSONData = [NSData dataWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"addata" ofType:@"json"]];
NSDictionary *jsonDict = [NSJSONSerialization JSONObjectWithData:JSONData options:NSJSONReadingAllowFragments error:nil];
demo下载地址:https://github.com/qqcc1388/TYWebViewInTableViewDemo/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· 因为Apifox不支持离线,我果断选择了Apipost!
2017-06-08 PyCharm for mac 破解版
2017-06-08 iOS中动态注入JavaScript方法。动态给html标签添加事件