ie瀏覽器對(duì)于同一個(gè)url只返回相同結(jié)果。因?yàn)椋谀J(rèn)情況下,ie會(huì)緩存ajax的請(qǐng)求結(jié)果。對(duì)于同一個(gè)url地址,在緩存過(guò)期之前,只有第一次請(qǐng)求會(huì)真正發(fā)送到服務(wù)端。大多數(shù)情況下,我們使用ajax是希望實(shí)現(xiàn)局部刷新的,所以這就牽扯到一個(gè)改進(jìn)的問(wèn)題。
如果想每次都獲取到最新數(shù)據(jù),我們只需保證每次傳入的url不一樣。最簡(jiǎn)單的方法就是通過(guò)給url拼接參數(shù)。利用math函數(shù)的random()方法生成隨機(jī)數(shù)。
比如訪問(wèn)百度www.baidu.com,我們就可以把地址寫成www.baidu.com?t=math.random();或者?t=new date().gettime();
********************************分割線**********************************
說(shuō)到這里,不妨復(fù)習(xí)一下ajax的基本用法。
*ajax創(chuàng)建對(duì)象:
var xmlhttp; if (window.xmlhttprequest){ //ie7+, firefox, chrome, opera, safari xmlhttp = new xmlhttprequest(); } else{ //ie6, ie5 xmlhttp=new activexobject("microsoft.xmlhttp"); }
*ajax請(qǐng)求:
//get請(qǐng)求: xmlhttp.open("get","test1.txt",true); xmlhttp.send(); //post請(qǐng)求: xmlhttp.open("post","demo_post.asp",true); xmlhttp.send();
get 還是 post?
與 post 相比,get 更簡(jiǎn)單也更快,并且在大部分情況下都能用。
然而,在以下情況中,請(qǐng)使用 post 請(qǐng)求:
無(wú)法使用緩存文件(更新服務(wù)器上的文件或數(shù)據(jù)庫(kù))
向服務(wù)器發(fā)送大量數(shù)據(jù)(post 沒(méi)有數(shù)據(jù)量限制)
發(fā)送包含未知字符的用戶輸入時(shí),post 比 get 更穩(wěn)定也更可靠
*ajax響應(yīng):
要獲得服務(wù)器的響應(yīng),需要使用xmlhttprequest 對(duì)象的 responsetext 或 responsexml 屬性。
responsetext:獲得字符串形式的響應(yīng)數(shù)據(jù)。
document.getelementbyid("mydiv").innerhtml=xmlhttp.responsetext;
responsexml:獲得xml形式的響應(yīng)數(shù)據(jù)。
如果來(lái)自服務(wù)器的響應(yīng)是 xml,而且需要作為 xml 對(duì)象進(jìn)行解析。
*ajax - onreadystatechange :
當(dāng)請(qǐng)求被發(fā)送到服務(wù)器時(shí),我們需要執(zhí)行一些基于響應(yīng)的任務(wù)。
每當(dāng) readystate 改變時(shí),就會(huì)觸發(fā) onreadystatechange 事件。
在 onreadystatechange 事件中,我們規(guī)定當(dāng)服務(wù)器響應(yīng)已做好被處理的準(zhǔn)備時(shí)所執(zhí)行的任務(wù)。
當(dāng) readystate 等于 4 且狀態(tài)為 200 時(shí),表示響應(yīng)已就緒:
xmlhttp.onreadystatechange=function() { if (xmlhttp.readystate==4 && xmlhttp.status==200) { document.getelementbyid("mydiv").innerhtml=xmlhttp.responsetext; } }
補(bǔ)充:下面看下淺談ajax解決瀏覽器的緩存問(wèn)題
ajax能提高頁(yè)面載入速度的主要原因是通過(guò)ajax減少了重復(fù)數(shù)據(jù)的載入,也即在載入數(shù)據(jù)的同時(shí)將數(shù)據(jù)緩存到內(nèi)存中,一旦數(shù)據(jù)被加載,只要沒(méi)有刷新頁(yè)面,這些數(shù)據(jù)就會(huì)一直被緩存在內(nèi)存中,當(dāng)提交的url與歷史的url一致時(shí),就不需要提交給服務(wù)器,也即不需要從服務(wù)器獲取數(shù)據(jù),雖然降低了服務(wù)器的負(fù)載,提高了用戶體驗(yàn),但不能獲取最新的數(shù)據(jù)。為了保證讀取的信息都是最新的,需要禁止其緩存功能。
解決方案有如下幾種:
① 在ajax發(fā)送請(qǐng)求前加上anyajaxobj.setrequestheader("if-modified-since", "0")。
② 在ajax發(fā)送請(qǐng)求前加上anyajaxobj.setrequestheader("cache-control", "no-cache")。
③ 在url后加上一個(gè)隨機(jī)數(shù):"fresh=" + math.random();。
④ 在url后加上時(shí)間搓:"nowtime=" + new date().gettime();。
⑤ 如果是使用jquery,則用$.ajaxsetup({cache:false})。這樣頁(yè)面的所有ajax都會(huì)執(zhí)行該語(yǔ)句而不需要保存緩存記錄。
總結(jié)
以上所述是小編給大家介紹的ie瀏覽器關(guān)于ajax的緩存機(jī)制,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)碩編程網(wǎng)站的支持!