清理浏览器网站缓存的几种方法(meta,form表单,ajax)

时间:2021-07-18 21:26:03

1.meta方法

  HTML header中加入

<meta http-equiv="pragma" content="no-cache">

说明:禁止浏览器从本地计算机的缓存中访问页面内容。上述设定,访问者将无法脱机浏览。

<meta http-equiv="Cache-Control" content="no-cache,must-revalidate">

说明:Cache-Control指定请求和响应遵循的缓存机制,no-cache指示请求或响应消息不能缓存,must-revalidate,对于客户机的每次请求,代理服务器必须想服务器验证缓存是           否过时;

<meta http-equiv="expires" content="0">

说明:可以用于设定网页的到期时间。一旦网页过期,必须到服务器上重新传输。

合起来用,就可以使你再次进入曾经访问过的页面时,浏览器必须从服务端下载最新的内容,达到刷新的效果。

2.清理form表单的临时缓存

  document.getElementById("YourFormID").reset();

说明:js重置表单(reset)的方法。

  在form中加入autocomplete='off'属性,或者在input中加入autocomplete='off'属性

  说明:关闭自动填充。

3.jquery--ajax清除缓存

  A.用ajax请求服务器最新文件,并加上请求头If-Modified-Since和Cache-Control,如下:

  $.ajax({
url:'',
dataType:'json',
beforeSend :function(xmlHttp){
xmlHttp.setRequestHeader("If-Modified-Since","0");
xmlHttp.setRequestHeader("Cache-Control","no-cache");
},
success:function(response){
}
});

B.直接用cache:false

  $.ajax({
url:',
dataType:'json',
cache:false,
success:function(response){
}
});

C.用随机数或者随机时间避免缓存

  $.ajax({
   //随机数
url:'YourURL?ran='+Math.random(),
dataType:'json',
success:function(response){
}
});
  $.ajax({
   //随机时间
url:'YourURL?timestamp='+ new Date().getTime(),
dataType:'json',
success:function(response){
}
});