2018 自适应WKWebView高度

2018-06-04  本文已影响14人  时光浅影

ArticalDetailCell.m

//
//  ArticalDetailCell.m
//  BlockChainNews
//
//  Created by zsm on 2018/5/30.
//  Copyright © 2018年 XinHuoKeJi. All rights reserved.
//

#import "ArticalDetailCell.h"

@interface ArticalDetailCell()<WKUIDelegate,WKNavigationDelegate>
@property (weak, nonatomic) IBOutlet UILabel *titileLab;
@property (weak, nonatomic) IBOutlet UILabel *timeLab;

@end

@implementation ArticalDetailCell


- (void)awakeFromNib {
    [super awakeFromNib];
    // Initialization code
    self.selectionStyle = UITableViewCellSelectionStyleNone;

    self.myWebView.backgroundColor = [UIColor clearColor];
    self.myWebView.scrollView.scrollEnabled = NO;
    [self.myWebView setUserInteractionEnabled:NO];//是否支持交互
    [self.myWebView.scrollView addObserver:self forKeyPath:@"contentSize" options:NSKeyValueObservingOptionNew context:nil];
    self.myWebView.navigationDelegate = self;
    self.myWebView.UIDelegate = self;
}
#pragma mark - WKNavigationDelegate
/* 页面开始加载 */
- (void)webView:(WKWebView *)webView didStartProvisionalNavigation:(WKNavigation *)navigation{
//    [SVProgressHUD show];
}
/* 开始返回内容 */
- (void)webView:(WKWebView *)webView didCommitNavigation:(WKNavigation *)navigation{
    
}
/* 页面加载完成 */
- (void)webView:(WKWebView *)webView didFinishNavigation:(WKNavigation *)navigation{

    [SVProgressHUD dismiss];
    if (webView.isLoading) {
        return;
    }
    __block CGFloat webViewHeight=0;
    //获取内容实际高度(像素)@"document.getElementById(\"content\").offsetHeight;"
    [webView evaluateJavaScript:@"document.body.offsetHeight" completionHandler:^(id _Nullable result,NSError * _Nullable error) {
        // 此处js字符串采用scrollHeight而不是offsetHeight是因为后者并获取不到高度,看参考资料说是对于加载html字符串的情况下使用后者可以,但如果是和我一样直接加载原站内容使用前者更合适
        //获取页面高度,并重置webview的frame
        webViewHeight = [result floatValue];
        NSLog(@"%f",webViewHeight);
        if (self.webViewHeightChanged) {
            self.webViewHeightChanged(webViewHeight);
        }
 
    }];
    
//    [webView evaluateJavaScript:@"document.body.offsetHeight" completionHandler:^(id _Nullable clientheight_str, NSError * _Nullable error) {
//        float clientheight = [clientheight_str floatValue];
//        webView.frame = CGRectMake(15, 10, kScreenWidth - 30, clientheight);
//
//        [webView evaluateJavaScript:@"" completionHandler:^(id _Nullable, NSError * _Nullable error) {
//
//        }];
//    }];
    

//    NSString * clientheight_str = [webView stringByEvaluatingJavaScriptFromString: @"document.body.offsetHeight"];
//    float clientheight = [clientheight_str floatValue];
//    //设置到WebView上
//    webView.frame = CGRectMake(15, 10, kScreenWidth - 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, 10, kScreenWidth - 30, height);
//
//    //下面这两行是去掉不必要的webview效果的(选中,放大镜)
//    [webView stringByEvaluatingJavaScriptFromString:@"document.documentElement.style.webkitUserSelect='none';"];
//
//    [webView stringByEvaluatingJavaScriptFromString:@"document.documentElement.style.webkitTouchCallout='none';"];
    
}
/* 页面加载失败 */
- (void)webView:(WKWebView *)webView didFailProvisionalNavigation:(WKNavigation *)navigation{
    [[UIApplication sharedApplication].delegate.window makeToast:@"页面加载失败" duration:1.0 position:CSToastPositionCenter];
    [SVProgressHUD dismiss];
}
/* 在发送请求之前,决定是否跳转 */
- (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler{
    //允许跳转
    decisionHandler(WKNavigationActionPolicyAllow);
    //不允许跳转
    //decisionHandler(WKNavigationActionPolicyCancel);
}
/* 在收到响应后,决定是否跳转 */
- (void)webView:(WKWebView *)webView decidePolicyForNavigationResponse:(WKNavigationResponse *)navigationResponse decisionHandler:(void (^)(WKNavigationResponsePolicy))decisionHandler{
    
    NSLog(@"%@",navigationResponse.response.URL.absoluteString);
    //允许跳转
    decisionHandler(WKNavigationResponsePolicyAllow);
    //不允许跳转
    //decisionHandler(WKNavigationResponsePolicyCancel);
}
//监听方法
- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context
{

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

        CGSize fitSize = [_myWebView sizeThatFits:CGSizeZero];
        //        NSLog(@"webview fitSize:%@",NSStringFromCGSize(fitSize));
        CGRect rect = self.myWebView.frame;
        rect.size.width = fitSize.width;
        rect.size.height = fitSize.height;
        self.myWebView.frame = rect;


    }
}
- (void)setModel:(TypeDetailModel *)model{
    self.titileLab.text = model.title;
    self.timeLab.text = [NSString stringWithFormat:@"发布日期:%@",[ToolUtil getTimeWithStamp:model.update_time]];
    NSString *result = [NSString stringWithFormat:@"<%@ %@",@"img",@"style='display: block; max-width: 100%;'"];
    NSString*contentStr = model.content;
    
    contentStr = [contentStr stringByReplacingOccurrencesOfString:@"<img" withString:result];
    
    NSString *htmlStr = [NSString stringWithFormat:@"<html><head><meta http-equiv=\'Content-Type\' content=\'text/html; charset=utf-8\'/><meta content=\'width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0;\' name=\'viewport\' /><meta name=\'apple-mobile-web-app-capable\' content=\'yes\'><meta name=\'apple-mobile-web-app-status-bar-style\' content=\'black\'><link rel=\'stylesheet\' type=\'text/css\' /><style type=\'text/css\'> .color{color:#576b95;}</style></head><body><div id=\'content\'>%@</div>", contentStr];
    
    //修改图片大小
    NSString *re_imgSize = [NSString stringWithFormat:@"<head><style>img{width:%f !important;height:auto}</style></head>",kScreenWidth - 60];
    
    NSString *htmlcontent = [NSString stringWithFormat:@"<head><style>img{max-width:%fpx !important;}</style></head><div id=\"webview_content_wrapper\">%@</div>%@",kScreenWidth-30,htmlStr,re_imgSize];
    [self.myWebView loadHTMLString:htmlcontent baseURL:nil];
    
    
}
//-(void)layoutSubviews
//{
//    [super layoutSubviews];
//}
//这里别忘了在dealloc理移除监听
- (void)dealloc {
    NSLog(@"webView ---------dealloc");
    [self.myWebView.scrollView removeObserver:self
                                 forKeyPath:@"contentSize" context:nil];
}




@end



ArticalDetailCell.h

//
//  ArticalDetailCell.h
//  BlockChainNews
//
//  Created by zsm on 2018/5/30.
//  Copyright © 2018年 XinHuoKeJi. All rights reserved.
//

#import <UIKit/UIKit.h>
#import "TypeDetailModel.h"
#import "UIWebView+isLoading.h"
#import "MyWK.h"
typedef void(^WebViewHeightChangedBlock)(float height);
@interface ArticalDetailCell : UITableViewCell<UIWebViewDelegate>
@property (weak, nonatomic) IBOutlet MyWK *myWebView;

//@property (weak, nonatomic) IBOutlet UIWebView *webView;
@property (nonatomic, strong) TypeDetailModel *model;
@property (nonatomic, strong) WebViewHeightChangedBlock webViewHeightChanged;

@end

视图控制器中使用

//MARK:-- 适配iOS10  加载wkwebview 底部留白 计算高度不准确
- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    
    if (self.tableView == scrollView) {
        
        for (UIView *cell in self.tableView.visibleCells) {
            
            if ([cell isKindOfClass:[ArticalDetailCell class]]) {
                
                [((ArticalDetailCell *)cell).myWebView setNeedsLayout];
                
            }
            
        }
        
    }
    
}

cellForRow中使用

ArticalDetailCell * cell = [tableView dequeueReusableCellWithIdentifier:reuseid forIndexPath:indexPath];
        if (self.model) {
            [cell setModel:self.model];
            
            cell.webViewHeightChanged = ^(float height){
                //MARK:--计算webview高度
                BOOL needReload = NO;
                if(self.webViewHeight == 0 ) needReload=YES;
                self.webViewHeight = height + 30;
                
                if (needReload) {
//                    needReload = NO;
                    [self.tableView reloadData];
                    DLog(@"callback --------webViewheight  %d",height);
                }
            };
        }
        return cell;
上一篇 下一篇

猜你喜欢

热点阅读