app内嵌H5 webview 本地缓存问题的解决
程序员文章站
2022-06-25 19:35:24
app内嵌H5 webview 本地缓存问题的解决这篇文章主要介绍了app内嵌H5 webview 本地缓存问题的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习... 20-10-19...
前文
app内嵌h5已经很普遍了,但是每个app提供的webview表现都不太一样,在开发中遇到了一个非常棘手的缓存问题。app启动时加载了我们商城项目的h5代码,然后把index.html文件缓存到了本地。
记录一下
问题表现
h5项目打包上线后,由于静态资源js和css文件名后面都带了哈希值,这是webpack打包带上的,也是为了=防止缓存。但是在app启动后由于缓存了html请求的还是上个版本包的静态资源,导致index.a878n.js找不到404,页面吧白屏了。-----我们h5项目打包上线后,服务器上上个版本的代码就清掉了。
解决办法
我们一开始给html加上了一段随机数,就是app加载到html时,在url后面加随机数,但是发现webview的html缓存,导致我们的js修改是更新不上的。
最后解决方案是,app端加载项目时在域名后加时间戳并升级app才可。
为了避免这种问题出现,那就是项目首次上线时就要在html内给url加上随机数,让webview不缓存html到本地。
前端大佬给推荐的是一开始就要配置nginx ,强制不缓存html
location / { expires -1; add_header 'cache-control' 'no-store, no-cache, must-revalidate, proxy-revalidate, max-age=0'; try_files $uri $uri/ @router; index index.html; }
到此这篇关于app内嵌h5 webview 本地缓存问题的解决的文章就介绍到这了,更多相关app内嵌html5 webview 本地缓存内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!