js文件被浏览器缓存了,清缓存

以前很少关注这方面的问题,直达我们的技术经理找我们说要换框架,为什么换框架呢,因为缓存的问题,原来的项目是用版本号作为刷新的依据的。因为微信 公众号上有这样一个机制,使用版本好的话,有时做不到及时刷新,所以就用了vue.js,因为它有这样的功能就是如果某个文件里面的数据改变了,那么vue.js就会把这个文件的名字也相应的改掉,所以缓存里面的东西 就用不了了,这样就做到了及时刷新,向后台请求数据。

以前没有总结过js关于清除浏览器缓存的方法,今天就借此总结一下吧。

浏览器缓存,有时候我们需要他,因为他可以提高网站性能和浏览器速度,提高网站性能。但是有时候我们又不得不清除缓存,因为缓存可能误事,出现一些错误的数据。像股票类网站实时更新等,这样的网站是不要缓存的,像有的网站很少更新,有缓存还是比较好的。今天主要介绍清除缓存的几种方法。

清理网站缓存的几种方法

meta方法


//
CONTENT=”no-cache” 清除缓存

//
CONTENT=”no-cache” 清除缓存
清理form表单的临时缓存
方式一:用ajax请求服务器最新文件,并加上请求头If-Modified-Since和Cache-Control,如下:

$.ajax({
url:’www.haorooms.com’,
dataType:’json’,
data:{},
beforeSend :function(xmlHttp){
xmlHttp.setRequestHeader(“If-Modified-Since”,”0”);
xmlHttp.setRequestHeader(“Cache-Control”,”no-cache”);
},
success:function(response){
//操作
}
async:false
});

async:false 是否异步加载。

方法二,直接用cache:false,

$.ajax({
url:’www.haorooms.com’,
dataType:’json’,
data:{},
cache:false,
ifModified :true ,

 success:function(response){
     //操作
 }
 async:false

});
同时关于ajax中的cache的介绍
ajax里的cache

true的话会读缓存,可能真的到服务器上。

假如上次访问了a.html,第二次的时候得到的是上次访问的a.html的结果,而不是重新到服务器获取。

false的话会在url后面加一个时间缀,让它跑到服务器获取结果。

cache只有GET方式的时候有效。
方法三:用随机数,随机数也是避免缓存的一种很不错的方法!

URL 参数后加上 “?ran=” + Math.random(); //当然这里参数 ran可以任意取了
eg:

document.write("

猜你喜欢

转载自blog.csdn.net/qq_42241895/article/details/82192648