给js加版本号解决浏览器缓存问题

我们知道打开网页时浏览器会加载需要的资源,比如图片、音频、js文件、css文件等。并且会把这些资源作为缓存保存下来,再次打开网页时缓存好的资源就不需要再次加载了。但是,这样有一个问题,就是当程序猿更新了网页内容后,因为浏览器缓存的存在,可能没有办法显示出更新后的内容。

今天我就遇到了这样的问题,做了一个小游戏的网页,用到了大量的图片和音频,测试时更新的js不能立刻反馈,总是需要清除缓存后刷新才能看到更新。但是大量的图片和音频,每次都需要清除缓存也太麻烦了,我就百度了一下有没有好的解决方法。

百度找到的解决方案就是给js添加版本号,这样每次更新版本号,浏览器就会重新加载js文件,如下:

document.write('<script src="js/main.js?v='+Math.random()+'"><\/script>');

通过随机数来自动添加版本号,不需要自己手动去添加,实在是省时省力!

 

不过,考虑到随机数有重复的可能性,即便两次随机数正好一样的可能性及其微小,也不为0,而且随机数也不够直观,不如直接使用时间戳,如下:

document.write('<script src="js/main.js?t='+new Date().getTime()+'"><\/script>');

永远不会停止流动的时间不可能重复,更何况还精确到了毫秒,而且时间戳也总比随机数更加明了,可以明确知道js版本的先后。

使用上述方式改了我的程序后,成功避免了缓存问题,不过打开控制台后,发现了新的问题......

谷歌浏览器对document.write()发出了警告,查看了谷歌浏览器的警告页,了解到了使用document.write()方式链接js文件会导致加载变慢,对网速不好的用户体验会变差,不过谷歌举的例子是使用2g的用户。

???

现在还有使用2g的史前人类吗?本来想无视这个警告,不过往下看后发现...谷歌浏览器在55版本之后,对于网速不好的用户,会禁止document.write()方式链接的js文件,范围扩大到了3g和状况不好的wifi...

这已经是不能忽视的情况了。

想到的解决方法如下:

<script type="text/javascript" src="js/1.js"></script>
<script type="text/javascript" src="js/2.js"></script>
<script type="text/javascript" src="js/3.js"></script>
<script type="text/javascript" src="js/4.js"></script>
<script type="text/javascript" src="js/5.js"></script>
<script>
    var scripts = document.getElementsByTagName("script");
    for(var i = 0;i < scripts.length;i ++){
        if(scripts[i].src){
            scripts[i].src = scripts[i].src+"?t="+new Date().getTime();
        }
    }
</script>

添加一段代码,动态添加时间戳。但是这样做有个弊端,可能会使浏览器加载两次js文件。

暂时没有想到更好的办法,先这样,有更好的办法再补充。

转载于:https://www.cnblogs.com/wblx/p/11050498.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js是一个JavaScript框架,用于构建用户界面。在使用Vue.js开发网站时,由于浏览器缓存的存在,可能会导致版本更新的问题浏览器缓存是指浏览器在第一次请求网页后,会将该网页的一些资源文件(例如JavaScript和CSS文件)保存在本地。当用户再次访问相同的网页时,浏览器会直接从本地缓存载这些资源文件,以提高网页的载速度。 然而,当使用Vue.js进行版本更新时,如果浏览器继续使用缓存的旧版本文件,就会导致网页显示异常或出现错误。为了解决这个问题,可以采取以下几种方法: 1. 使用文件版本号:在引入CSS和JavaScript文件时,可以在文件名中添一个版本号,例如app.js?v=1.0。每次更新版本时,只需修改版本号即可,这样浏览器会认为是不同的文件,强制重新载。 2. 添Cache-Control头信息:通过在服务器端的响应头信息中添Cache-Control字段,指定浏览器是否应该缓存文件,以及缓存的有效期。通过设置"no-cache"或"no-store"可以禁止浏览器缓存文件。 3. 使用Webpack的chunkhash:在使用Webpack打包项目时,可以使用chunkhash生成唯一的文件名,例如app.f8293f3.js。每次更新时,Webpack会自动生成新的chunkhash,从而强制浏览器重新载文件。 除了以上方法,还可以使用一些高级技术,如Service Worker来实现离线缓存和更新策略,或使用CDN来分发文件,以避免缓存问题。 总而言之,更新Vue.js版本时,需要考虑到浏览器缓存的存在。通过使用文件版本号、设置Cache-Control头信息或使用Webpack的chunkhash等方法,可以解决浏览器缓存问题,确保网页能够正确载最新的文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值