iOS中精确计算WebView高度的方法示例
前言
在开发app的过程中难免会遇到将webView加载到tableView的cell上的需求,一般遇到这种问题,通常想到的思路就是在webView的回调方法webViewDidFinishLoad中获取到webView的高度,刷新tableView,将高度赋值给tableView的回调方法heightForRow。看似没有任何问题,但是在实际操作的时候却发现得到的高度并不是webView的实际高度,显然这种方法是行不通的。其实并不是方法不行,而是webViewDidFinishLoad代理方法被调用时,页面并不一定完全展现完成,可能有图片还未加载出来,导致此时获取的高度是并不是最终高度,过会儿图片加载出来后,浏览器会重新排版,而我们在这之前给了一个错误高度,导致显示异常。既然这种方法行不通,那么到底如何才能准确计算webView的高度呢?
答案是监听,具体的实现过程如下:
给webView的scrollView的contentSize属性添加监听,每当内容发生变化,contentSize一定会跟着变,捕获这个变动,在监听方法中实现webViewDidFinishLoad中的代码,也就是获取最新的内容高度赋给webView:
//添加监听 [_WebView.scrollViewaddObserver:selfforKeyPath:@"contentSize"options:NSKeyValueObservingOptionNew|NSKeyValueObservingOptionOldcontext:@"WejinWuLiuViewController"];
//监听回调 -(void)observeValueForKeyPath:(NSString*)keyPathofObject:(id)objectchange:(NSDictionary*)changecontext:(void*)context{ if([keyPathisEqualToString:@"contentSize"]){ _webViewHeight=[_WebView.scrollViewcontentSize].height; CGRectnewFrame=_WebView.frame; newFrame.size.height=_webViewHeight; _WebView.frame=newFrame; } }
iOS开发之解决WebView自适应内容高度
首先如果直接进行内容展示,或者进行sizeToFit的操作,那么可能会造成图片超过屏幕大小,字体变得很小的结果,所以这里用到了UIWebView的delegate方法和添加了html的标签语言,使用了javascript操作方法。具体可以研究代码,如下:
//web
-(UIWebView*)detailWebView
{
if(_detailWebView==nil){
_detailWebView=[UIWebViewnew];
_detailWebView.delegate=self;
_detailWebView.scrollView.bounces=NO;
_detailWebView.scrollView.showsHorizontalScrollIndicator=NO;
_detailWebView.scrollView.scrollEnabled=NO;
_detailWebView.dataDetectorTypes=UIDataDetectorTypeAll;
[_detailWebViewsizeToFit];
}
return_detailWebView;
}
NSString*htmlcontent=[NSStringstringWithFormat:@"%@
#pragmamark-----webView的delegate
-(void)webViewDidFinishLoad:(UIWebView*)webView
{
//获取页面高度(像素)
NSString*clientheight_str=[webViewstringByEvaluatingJavaScriptFromString:@"document.body.offsetHeight"];
floatclientheight=[clientheight_strfloatValue];
//设置到WebView上
webView.frame=CGRectMake(15,_whereNewsLabel.bottom+10,f_Device_w-30,clientheight);
//下面这样写就是获取到比较准确的内容高度,不需要再进行其他计算了
//获取内容实际高度(像素)
NSString*height_str=[webViewstringByEvaluatingJavaScriptFromString:@"document.getElementById('webview_content_wrapper').offsetHeight+parseInt(window.getComputedStyle(document.getElementsByTagName('body')[0]).getPropertyValue('margin-top'))+parseInt(window.getComputedStyle(document.getElementsByTagName('body')[0]).getPropertyValue('margin-bottom'))"];
floatheight=[height_strfloatValue];
//再次设置WebView高度(点)
webView.frame=CGRectMake(15,_whereNewsLabel.bottom+10,f_Device_w-30,height);
if([self.delegaterespondsToSelector:@selector(backWebViewWithHeight:)]){
[self.delegatebackWebViewWithHeight:webView.bottom+5];
}
}
有写代码是我项目中使用的,没有必要用,大家可以根据自己的需要修改,必要的代码上面都有
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。