天天看點

html js清除緩存,js清除浏覽器緩存的幾種方法

JS 緩存的問題一直都是我們又愛又恨的東西。也是我們比較頭痛的問題, 一方面為了提高網站響應速度,減少伺服器的負擔,和節省帶寬,将需要将靜态資源緩存在用戶端, 但是另一方面,當js 檔案有改動的時候,如何快速的将用戶端緩存的js檔案都失效,這是非常頭痛的問題。 以至于每次客戶回報問題的時候,我們第一個解決辦法都是清理浏覽器緩存。

一、使用參數

第一、腳本并不存在,而是服務端動态生成的,是以帶了個版本号,以示差別。 即上面代碼對于檔案來說 等價于 但浏覽器會認為他是 該檔案的某個版本!

第二、用戶端會緩存這些css或js檔案,是以每次更新了js或css檔案後,改變版本号,用戶端浏覽器就會重新下載下傳新的js或css檔案 ,重新整理緩存的作用。

第二種情況最多,也可能兩種同時存在。

版本号,可以是一個随機數,也可以是一個遞增的值,大版本小版本的方式,或者根據腳本的生成時間書寫,比如就是精确到了生成腳本的秒,而 2.3.3 就是大版本小版本的方式。

二、清除浏覽器緩存的幾種方法

1. meta方法

//不緩存

2. 清理form表單的臨時緩存

其實form表單的緩存對于我們書寫還是有幫助的,一般情況不建議清理,但是有時候為了安全問題等,需要清理一下!

3. jquery ajax清除浏覽器緩存

方法一,用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

});

方法二,直接用cache:false,

$.ajax({

url:'www.haorooms.com',

dataType:'json',

data:{},

cache:false,

ifModified :true ,

success:function(response){

//操作

}

async:false

});

方法三:用随機數,随機數也是避免緩存的一種很不錯的方法!

URL 參數後加上 “?ran=” + Math.random(); //當然這裡參數 ran可以任意取了

方法四:用随機時間,和随機數一樣。

在 URL 參數後加上 “?timestamp=” + new Date().getTime();

4. 用php後端清理

在服務端加 header(“Cache-Control: no-cache, must-revalidate”);等等(如php中)