項(xiàng)目有時(shí)要用一些Ajax的效果,因?yàn)楸容^簡單,也就沒有去用什么Ajax.net之類的東西,手寫代碼也就實(shí)現(xiàn)了。、
第二天,有人向我報(bào)告錯(cuò)誤;說是只有第一次讀取的值正常,后面的值都不正常;我調(diào)試了一下 ,確實(shí)有這樣的問題,查出是因?yàn)锳JAX緩存的問題:解決辦法有如下幾種:
1、在服務(wù)端加 header("Cache-Control: no-cache, must-revalidate");(如php中)
2、在ajax發(fā)送請求前加上 anyAjaxObj.setRequestHeader("If-Modified-Since","0");
3、在ajax發(fā)送請求前加上 anyAjaxObj.setRequestHeader("Cache-Control","no-cache");
4、在 Ajax 的 URL 參數(shù)后加上 "?fresh=" + Math.random(); //當(dāng)然這里參數(shù) fresh 可以任意取了
5、第五種方法和第四種類似,在 URL 參數(shù)后加上 "?timestamp=" + new Date().getTime();
6、用POST替代GET:不推薦
1、加個(gè)隨機(jī)數(shù)
xmlHttp.open("GET", "ajax.asp?now=" + new Date().getTime(), true);
2、在要異步獲取的asp頁面中寫一段禁止緩存的代碼:
Response.Buffer =True
Response.ExpiresAbsolute =Now() - 1
Response.Expires=0
Response.CacheControl="no-cache"
3、在ajax發(fā)送請求前加上xmlHTTP.setRequestHeader("If-Modified-Since","0");可以禁止緩存
xmlHTTP.open("get", URL, true);
xmlHTTP.onreadystatechange = callHTML;
xmlHTTP.setRequestHeader("If-Modified-Since","0");
xmlHTTP.send();
另一個(gè)作者寫到:
AJAX的緩存是由瀏覽器維持的,對于發(fā)向服務(wù)器的某個(gè)url,ajax僅在第一次請求時(shí)與服務(wù)器交互信息,之后的請求中,ajax不再向服務(wù)器提交請求,而是直接從緩存中提取數(shù)據(jù)。
有些情況下,我們需要每一次都從服務(wù)器得到更新后數(shù)據(jù)。思路是讓每次請求的url都不同,而又不影響正常應(yīng)用:在url之后加入隨機(jī)內(nèi)容。
e.g.
url=url+"&"+Math.random();
Key points:
1.每次請求的url都不一樣(ajax的緩存便不起作用)
2.不影響正常應(yīng)用(最基本的)
----------------
方法二:(未經(jīng)證實(shí))
在JSP中禁止緩存
response.addHeader("Cache-Control", "no-cache");
response.addHeader("Expires", "Thu, 01 Jan 1970 00:00:01 GMT");
HTTP:
<META HTTP-EQUIV="pragma" CONTENT="no-cache">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">
<META HTTP-EQUIV="expires" CONTENT="Wed, 26 Feb 1997 08:21:57 GMT">
<META HTTP-EQUIV="expires" CONTENT="0">
另一個(gè)作者寫到:
我們都知道,ajax能提高頁面載入的速度的主要原因是通過ajax減少了重復(fù)數(shù)據(jù)的載入,真正做到按需獲取,既然如此,我們在寫ajax程序的時(shí)候不妨送佛送到西,在客戶端再做一次緩存,進(jìn)一步提高數(shù)據(jù)載入速度。那就是在載入數(shù)據(jù)的同時(shí)將數(shù)據(jù)緩存在瀏覽器內(nèi)存中,一旦數(shù)據(jù)被載入,只要頁面未刷新,該數(shù)據(jù)就永遠(yuǎn)的緩存在內(nèi)存中,當(dāng)用戶再次查看該數(shù)據(jù)時(shí),則不需要從服務(wù)器上去獲取數(shù)據(jù),極大的降低了服務(wù)器的負(fù)載和提高了用戶的體驗(yàn)。
參考:
http://www.cnblogs.com/yslow/archive/2009/08/28/1555777.html
http://www.cnblogs.com/yslow/archive/2009/08/28/1555856.html
http://www.cnblogs.com/quange/archive/2009/07/24/1529958.html