iOS中精确计算WebView高度的方法示例

2025-05-29 0 85

前言

在开发app的过程中难免会遇到将webView加载到tableView的cell上的需求,一般遇到这种问题,通常想到的思路就是在webView的回调方法webViewDidFinishLoad中获取到webView的高度,刷新tableView,将高度赋值给tableView的回调方法heightForRow。看似没有任何问题,但是在实际操作的时候却发现得到的高度并不是webView的实际高度,显然这种方法是行不通的。其实并不是方法不行,而是webViewDidFinishLoad代理方法被调用时,页面并不一定完全展现完成,可能有图片还未加载出来,导致此时获取的高度是并不是最终高度,过会儿图片加载出来后,浏览器会重新排版,而我们在这之前给了一个错误高度,导致显示异常。既然这种方法行不通,那么到底如何才能准确计算webView的高度呢?

答案是监听,具体的实现过程如下:

给webView的scrollView的contentSize属性添加监听,每当内容发生变化,contentSize一定会跟着变,捕获这个变动,在监听方法中实现webViewDidFinishLoad中的代码,也就是获取最新的内容高度赋给webView:

?

1

2
//添加监听

[_WebView.scrollView addObserver:self forKeyPath:@"contentSize" options:NSKeyValueObservingOptionNew | NSKeyValueObservingOptionOld context:@"WejinWuLiuViewController"];

?

1

2

3

4

5

6

7

8

9

10

11
//监听回调

- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSKeyValueChangeKey,id> *)change context:(void *)context{

if ([keyPath isEqualToString:@"contentSize"]) {

_webViewHeight = [_WebView.scrollView contentSize].height;

CGRect newFrame = _WebView.frame;

newFrame.size.height = _webViewHeight;

_WebView.frame = newFrame;

}

}

iOS开发之解决WebView自适应内容高度

首先如果直接进行内容展示,或者进行sizeToFit的操作,那么可能会造成图片超过屏幕大小,字体变得很小的结果,所以这里用到了UIWebView的delegate方法和添加了html的标签语言,使用了javascript操作方法。具体可以研究代码,如下:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14
//web

-(UIWebView *)detailWebView

{

if (_detailWebView == nil) {

_detailWebView = [UIWebView new];

_detailWebView.delegate = self;

_detailWebView.scrollView.bounces = NO;

_detailWebView.scrollView.showsHorizontalScrollIndicator = NO;

_detailWebView.scrollView.scrollEnabled = NO;

_detailWebView.dataDetectorTypes = UIDataDetectorTypeAll;

[_detailWebView sizeToFit];

}

return _detailWebView;

}

?

1

2

3
NSString *htmlcontent = [NSString stringWithFormat:@"<head><style>img{max-width:%fpx !important;}</style></head><div id=\\"webview_content_wrapper\\">%@</div>",f_Device_w-30,detailDic[@"content"]];

[_detailWebView loadHTMLString:htmlcontent baseURL:nil];

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21
#pragma mark ----- webView 的 delegate

- (void)webViewDidFinishLoad:(UIWebView *)webView

{

//获取页面高度(像素)

NSString * clientheight_str = [webView stringByEvaluatingJavaScriptFromString: @"document.body.offsetHeight"];

float clientheight = [clientheight_str floatValue];

//设置到WebView上

webView.frame = CGRectMake(15, _whereNewsLabel.bottom+10, f_Device_w-30, clientheight);

//下面这样写就是获取到比较准确的内容高度,不需要再进行其他计算了

//获取内容实际高度(像素)

NSString * height_str= [webView stringByEvaluatingJavaScriptFromString: @"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'))"];

float height = [height_str floatValue];

//再次设置WebView高度(点)

webView.frame = CGRectMake(15, _whereNewsLabel.bottom+10, f_Device_w-30, height);

if ([self.delegate respondsToSelector:@selector(backWebViewWithHeight:)]) {

[self.delegate backWebViewWithHeight:webView.bottom+5];

}

}

有写代码是我项目中使用的,没有必要用,大家可以根据自己的需要修改,必要的代码上面都有

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对快网idc的支持。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 iOS中精确计算WebView高度的方法示例 https://www.kuaiidc.com/89904.html

相关文章

发表评论
暂无评论