码迷,mamicode.com
首页 > 其他好文 > 详细

SPA页面缓存再优化二

时间:2018-06-13 18:44:14      阅读:313      评论:0      收藏:0      [点我收藏+]

标签:删除   css   浏览器   点击   控制   技术   请求   链接   路由   

部署到线上的步骤:

拿到打包之后的文件,删除服务器上的文件,再放上去的。

测试1:

更改js文件,删除并上传新包。

额外发现1:如果用户在上传期间,仍然在系统之内,此时即使将服务器上的包删除掉,用户不会跳出系统,只会在控制台上报错。

报错内容:

技术分享图片

只是在报错服务器上没有指定的html文件

额外发现2:

已经被缓存了的页面html 刚进页面时会进行从服务器200取到,随后删除服务器的包,已经被缓存下来的html页面是可以正常操作的。

此时再上传新包,用户仍然在已经缓存的页面里,按照老系统正常跑。访问未缓存的页面,再看引用的js与css文件,还是在使用老的js与css,并不是最新的,只是html因为是从服务器上取来的,所以取到的html是最新的。

在发现1的情况下,再将删除的包恢复,这时又可以正常访问了,控制台不再报错,不过系统还是在请求老的js文件。

 用户在登录界面上操作时,仍然这样。

 技术分享图片

用户如果点击退出,会取到最新部署的包。

用户点击收藏在浏览器上的地址,也会重新获取包。

用户重新输入网址,也会重新重新获取包。

从官网测试链接跳转,会重新获取包

 

测试2:

用户在系统之外,更新系统。是没有缓存的。

 

综上得到的结论

当单页面的系统在重新部署更新时,此时正在浏览网页,并且已经在网页内的用户,始终会使用老的js与css文件,一直在使用已经缓存了的静态资源。

所有的缓存问题焦点都在index.html上,只要index.html刷新即可重新获取代码。

解决方案:

1:在路由跳转时即刷新index页面

缺点:不管有没有更新部署,页面都会得到刷新。

2:在打包之后的dist文件夹里插入一个js文件,作为版本监控,每次路由转变/发送请求时,对这个js文件做回调,并且这个js文件,不被引入index内。

 

SPA页面缓存再优化二

标签:删除   css   浏览器   点击   控制   技术   请求   链接   路由   

原文地址:https://www.cnblogs.com/mamimi/p/9179244.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!