Android WebView的坑

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 :最适合自己的才是最好的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,081评论 25 709
  • 用两张图告诉你,为什么你的 App 会卡顿? - Android - 掘金 Cover 有什么料? 从这篇文章中你...
    hw1212阅读 13,085评论 2 59
  • 文丨桑白 参赛编号: 019 1. 邓驹最近心情很差,他上个月向相恋五年的女友求婚,结果把女友吓得落荒而逃。随后...
    桑白阅读 613评论 11 16
  • 练习打坐二十多天了,偶尔会在网上看看其他练习者的感悟,心得什么的,不过也只是草草的翻看,并不想知道练习多久会有什么...
    mnnyoo阅读 2,853评论 0 2