背景:
客户端在打开h5的时候,先展示loading,等h5在页面加载完成后通过jsBridge通知客户端去隐藏loading。
问题:
偶现,进了h5页但迟迟没有隐藏loading。
而且是很简单的展示一段纯文字的页面才有问题,比较复杂的页面反而不会有问题。
(是在Android上发现的问题,iOS由于还没上线未知。)
定位问题:
h5已经确定调用了桥,而客户端却也坚称没有收到h5调用桥的通知。
jsBridg是一直在使用的,之前没有遇到类似问题。
但定位到了这里,已经可以基本排除是开发层面的bug。
即使再不相信,也得遵从事实,继续往下从底层代码定位问题。
对h5端调用的jsbridge底层代码打log:
正常情况下log如下:
—in else
—WebViewJavascriptBridgeReady
出问题的时候:
—in else
那么出问题的时候就是因为WebViewJavascriptBridgeReady事件没有触发了。
而这个事件是在客户端webview的onPageFinished中触发。
网上一搜发现很多人反馈onPageFinished这个方法的调用时机有问题,可能提前,可能迟迟不调用,相较之下,onProgressChanged方法会更靠谱一点。
在此摘取其中一个:
(出处:https://www.zhihu.com/question/31316646)
最终解决方案:
使用onProgressChanged替代onPageFinished,改完就没发现问题了。但由于是改了底层的代码,所以后续需要观察看看有没有其它问题。