有的時候會碰見類似的苦逼需求, webview自適應實際內容高度 下麵有四種方法供使用 方法1:獲取webview中scrovllview的contentsize進行設置 1 2 3 4 5 6 -(void)webViewDidFinishLoad:(UIWebView *)webView{ CG ...
有的時候會碰見類似的苦逼需求, 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 的高度
}
}
}
}
|