鸿 网 互 联 www.68idc.cn

当前位置 : 服务器租用 > 操作系统维护 > 其它 > >

ios webview自适应实际内容高度4种方法

来源:互联网 作者:佚名 时间:2017-09-09 16:59
有的时候会碰见类似的苦逼需求, webview自适应实际内容高度 下面有四种方法供使用 方法1:获取webview中scrovllview的contentsize进行设置 123456 - ( void ) webViewDidFinishLoad : ( UIWebView * ) webView { CGFloat webViewHeight = [ webView . scrol

有的时候会碰见类似的苦逼需求, webview自适应实际内容高度 下面有四种方法供使用

方法1:获取webview中scrovllview的contentsize进行设置

 
1 2 3 4 5 6 -(void)webViewDidFinishLoad:(UIWebView *)webView{     CGFloat webViewHeight=[webView.scrollView contentSize].height;     CGRect newFrame = webView.frame;     newFrame.size.height = webViewHeight;     webView.frame = newFrame; }

方法2:执行js语句 直接获取html文档的dom高度

 
1 2 3 4 5 6 7 -(void)webViewDidFinishLoad:(UIWebView *)webView{     CGFloat webViewHeight= [[webView stringByEvaluatingJavaScriptFromString: @"document.body.offsetHeight"]floatValue]; // CGFloat webViewHeight= [[webView stringByEvaluatingJavaScriptFromString: @"document.body.scrollHeight"]floatValue];     CGRect newFrame = webView.frame;     newFrame.size.height = webViewHeight;     webView.frame = newFrame; }

方法3.先将UIWebView的高度设为最小,然后再使用sizeThatFits就会返回刚好合适的大小

 
1 2 3 4 5 6 -(void)webViewDidFinishLoad:(UIWebView *)webView{     CGSize actualSize = [webView sizeThatFits:CGSizeZero];     CGRect newFrame = webView.frame;     newFrame.size.height = actualSize.height;     webView.frame = newFrame; }

方法4.遍历webview子视图 获取UIWebDocumentView高度即实际高度

 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 -(void)webViewDidFinishLoad:(UIWebView *)webView{     CGFloat webViewHeight = 0.0f;     if ([webView.subviews count] > 0)     {         UIView *scrollerView = webView.subviews[0];         if ([scrollerView.subviews count] > 0)         {             UIView *webDocView = scrollerView.subviews.lastObject;             if ([webDocView isKindOfClass:[NSClassFromString(@"UIWebDocumentView") class]])             {                 webViewHeight = webDocView.frame.size.height;//获取文档的高度                 webView.frame= webDocView.frame; //更新UIWebView 的高度             }         }     } }

 

网友评论
<