美文网首页
iOS 计算webView中内容的高度

iOS 计算webView中内容的高度

作者: XiaoL_coder | 来源:发表于2017-08-21 12:54 被阅读142次

    当界面中的view需要根据webView的高度做适配时,就需要获取webView的高度

    做法:

    1. 对webView中的scrollView的contentSize添加键值监听,当webView滚动时,contentSize发生变化
    2. 在监听回调中获取最新的webview的高度,然后赋值给当前的webView。这里获取到的size就是webView的实时高度,可以正常使用
    - (void)viewDidLoad {
        [super viewDidLoad];
    
        [self.view addSubview:self.scrollView];
        [self.scrollView addSubview:self.testView];
        [self.scrollView addSubview:self.webView];
        
        NSString *url = @"http://hybrid.ximalaya.com/api/info/contact_us?app=iting&version=6.3.6&impl=com.gemd.iting";
        
        [self.webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:url]]];
        //监听webView中scrollView的contentSize的变化
        [self.webView.scrollView addObserver:self forKeyPath:NSStringFromSelector(@selector(contentSize)) options: ( NSKeyValueObservingOptionNew|NSKeyValueObservingOptionOld) context:nil];
    }
    
    - (void)dealloc{
        [self.webView.scrollView removeObserver:self forKeyPath:NSStringFromSelector(@selector(contentSize))];
    }
    
    - (void)webViewDidFinishLoad:(UIWebView *)webView{
        
    }
    
    //监听的回调
    - (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSKeyValueChangeKey,id> *)change context:(void *)context{
        if ([keyPath isEqualToString:NSStringFromSelector(@selector(contentSize))]) {
            //获取webView的size
           //sizeThatFits: 返回一个合适的大小以布局,默认实现是返回当前视图的已知大小
            CGSize webViewSize = [self.webView sizeThatFits:CGSizeZero];
            
            CGRect frame = self.webView.frame;
            frame.size = webViewSize;
            self.webView.frame = frame;
            //下面这段代码是根据自己的需求写的,可以在这个位置实现自己的需求
            self.scrollView.contentSize = CGSizeMake(webViewSize.width, webViewSize.height + 100);
    
        }
    }
    

    相关文章

      网友评论

          本文标题:iOS 计算webView中内容的高度

          本文链接:https://www.haomeiwen.com/subject/ebecdxtx.html