更新js缓存办法
2012-07-28 11:27
106 查看
/article/4117513.html
遇到的问题:
在访问量比较大的系统中,我们需要将一些静态的文件在客户端缓存,以减少下载的流量,从而加快客户端访问的速度。但是缓存会带来一个问题,就是如何在服务端更新完文件之后,客户端能够及时得到更新。
解决思路:
1. 在一个配置文件中维护js文件map;
2. 在页面中通过js map的key来动态加载js文件;
3. 在js文件做出变动之后,只要修改相应js的版本号
实例:
1. 在一个配置文件(config.js)中维护js文件map(注意:config.js是不缓存的,每次更新)
Js代码
//js Map
var JSHash = {
index: [{url:"http://xxxx.js", version: "1.0"}],
edit: [{url:"http://xxxx.js", version: "2.0"}]
}
2. 在页面中通过js map的key来动态加载js文件;
Html代码
<script src=config.js></script>
<script>
loadJS("edit");
</script>
//根据传入的key,动态生成js加载语句
function loadJS(sKey) {
var node = JSHash[sKey];
for(var i =0;i < node.length; i ++) {
document.writeln('<script src="'+node[i].url+'?version='+node[i].version+'"><\/script>');
}
}
//-->
</script>
3. 在js文件做出变动之后,只要修改相应js的版本号即可.这样由于链接不一样了,就会对这个变动的js进行重新下载。其他js由于链接不变,所以仍旧使用缓存中的js.
遇到的问题:
在访问量比较大的系统中,我们需要将一些静态的文件在客户端缓存,以减少下载的流量,从而加快客户端访问的速度。但是缓存会带来一个问题,就是如何在服务端更新完文件之后,客户端能够及时得到更新。
解决思路:
1. 在一个配置文件中维护js文件map;
2. 在页面中通过js map的key来动态加载js文件;
3. 在js文件做出变动之后,只要修改相应js的版本号
实例:
1. 在一个配置文件(config.js)中维护js文件map(注意:config.js是不缓存的,每次更新)
Js代码
//js Map
var JSHash = {
index: [{url:"http://xxxx.js", version: "1.0"}],
edit: [{url:"http://xxxx.js", version: "2.0"}]
}
//js Map var JSHash = { index: [{url:"http://xxxx.js", version: "1.0"}], edit: [{url:"http://xxxx.js", version: "2.0"}] }
2. 在页面中通过js map的key来动态加载js文件;
Html代码
<script src=config.js></script>
<script>
loadJS("edit");
</script>
//根据传入的key,动态生成js加载语句
function loadJS(sKey) {
var node = JSHash[sKey];
for(var i =0;i < node.length; i ++) {
document.writeln('<script src="'+node[i].url+'?version='+node[i].version+'"><\/script>');
}
}
//-->
</script>
<script src=config.js></script> <script> loadJS("edit"); </script> //根据传入的key,动态生成js加载语句 function loadJS(sKey) { var node = JSHash[sKey]; for(var i =0;i < node.length; i ++) { document.writeln('<script src="'+node[i].url+'?version='+node[i].version+'"><\/script>'); } } //--> </script>
3. 在js文件做出变动之后,只要修改相应js的版本号即可.这样由于链接不一样了,就会对这个变动的js进行重新下载。其他js由于链接不变,所以仍旧使用缓存中的js.
相关文章推荐
- CSS和JS更新,缓存同步更新解决办法
- web网站css,js更新后客户浏览器缓存问题,需要刷新才能正常展示的解决办法
- web网站css,js更新后客户浏览器缓存问题,需要刷新才能正常展示的解决办法
- 【转载】web网站css,js更新后客户浏览器缓存问题,需要刷新才能正常展示的解决办法
- web网站css,js更新后客户浏览器缓存问题,需要刷新才能正常展示的解决办法
- 【转载】----web网站css,js更新后客户浏览器缓存问题,需要刷新才能正常展示的解决办法
- web网站css,js更新后客户浏览器缓存问题,需要刷新才能正常展示的解决办法
- 前端工程精粹(一):静态资源版本更新与缓存(附精简js的工具)
- 解决修改css或js文件,浏览器缓存更新问题。
- dede 修复更新联动缓存 不更新联动js的bug
- 网页缓存Js,css以及图片导致页面刷新无效果的三种解决办法
- 项目js文件修改后chrome不能及时更新的解决办法
- js的动态加载、缓存、更新以及复用(二)
- js的动态加载、缓存、更新以及复用(三)
- 项目中js文件修改后浏览器不能及时更新的解决办法
- 上线项目更新版本后如何避免客户端js和css缓存
- 项目中js文件修改后浏览器不能及时更新的解决办法
- js的动态加载、缓存、更新以及复用
- 前端静态资源版本更新与缓存之——通过gulp 在原html文件上自动化添加js、css版本号
- 关于更新发布css和js文件的缓存问题