Android WebView的坑

记录一些webview比较隐晦难查的问题。

  1. 系统字体改变大小影响WebView内网页的字体大小:设置WebView.setTextZoom(100),字体大小就只会由网页改动,不随系统变化。

  2. 三星手机进入webview后息屏一分钟再亮屏退出webview再进入,webview白屏:三星手机部分系统有「特殊的」省电优化,息屏后会导致webview内部长连接断开,任何请求都失效了。解决办法:每次进来都重新创建webview,因此退出的时候必须要销毁,也保证了不会造成内存泄露。可是依然存在息屏后继续操作webview,这时候网页内所有的请求失效,此问题没有很好的解决办法,webview也没有提供对应的重连api,可行方案:部分手机亮屏刷新页面,直接重建webview。

  3. webview内存泄露:

1. 需要动态创建:WebView webview = new WebView(context); 
2. 销毁:
    if(webview != null ){
        webview.destroy();
        ViewGroup parent = (ViewGroup)webview.getParent();
        if(parent != null){
            parent.removeView(webview);
        }
        webview = null;
    }
复制代码
  1. webview返回上一级总是会刷新:从二级页面返回到上一级没法控制不刷新。方案:1. webview.setCacheMode(LOAD_CACHE_ONLY), 只用缓存这种方式基本不适合大部分需求。2. 跳到二级页面时重新创建一个webview,实现下返回逻辑。但是如果层级太多也不适合,适合那种一级页面强制要求不能返回刷新,二级以上的页面没有这种限制的需求。

  2. 网页无法播放视频、滑动不顺畅:开启硬件加速。

  3. 开启硬件加速的问题:

  • 硬件加速3.0以上就支持了,但是部分低版本的手机开启硬件加速后,可能会出现闪屏、卡顿等现象;
  • 部分H5的组件、原生自定义的组件不支持硬件加速。因此只能在性能和bug中抉择。。。
  • 低版本手机RAM小,而硬件加速需要很大的内存,所以低版本开了硬件加速反而卡顿。
  • 方案:1. 拿到userAgent中的chrome内核版本,抉择下支持硬件加速的最低chrome内核版本。2.直接选定一个Android最低支持硬件加速的版本,个人认为4.4是个不错的分界点。不过这些方案都不是很完美的,部分手机还是有第5点问题。WebView是真的坑。。。
  1. 支持HTTP2的前提条件是:Android版本4.4及以上 + Chrome内核版本41及以上。

持续更新中。。。

总结:webview的坑很多,H5性能上本就是一个很大的痛点,webview还搞这么多事儿。。如果项目中问题很多的话,可以尝试下腾讯x5内核,兼容性更强、速度更快、大厂的技术支持,但依然会碰到一些坑。并且现在也有很多的热更新方案:ReactNative、Weex等等,但兼容性都不是很好,要根据业务场景进行抉择了。

ps :最适合自己的才是最好的。

转载于:https://juejin.im/post/5c3d7d5d6fb9a049bb7c968a

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值