国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

淺析IE瀏覽器關(guān)于ajax的緩存機(jī)制

瀏覽:78日期:2022-06-11 11:51:12

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,我們就可以把地址寫(xiě)成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)站的支持!

標(biāo)簽: Ajax
相關(guān)文章:
主站蜘蛛池模板: 成年人毛片网站 | 亚洲午夜在线播放 | 国产精品亚洲午夜不卡 | 欧美jizzhd精品欧美高清 | 香蕉成人国产精品免费看网站 | 国产在视频线精品视频二代 | 欧美性色欧美a在线播放 | 免费观看黄色毛片 | 国产成人丝袜视频在线视频 | 国产高清国产专区国产精品 | 美女被免费网站视频软件 | 日本三级欧美三级人妇英文 | 成人a在线 | 国产亚洲一区二区三区在线观看 | 精品一久久香蕉国产线看播放 | 一区精品视频 | 国产精品一国产精品 | 日本韩国台湾香港三级 | 亚洲视频国产 | 精品xxxxxbbbb欧美中文 | 精品国产精品国产 | 国内精品福利在线视频 | 国产一区二区三区欧美 | 欧美黑人xxxxxxxxxx | 韩国美女一级毛片 | 亚洲国产精品久久卡一 | 免费观看欧美一级牲片一 | 手机在线成人精品视频网 | 能在线观看的一区二区三区 | 一本久久道久久爱 | 亚洲在线观看免费视频 | 精品国产视频在线观看 | 国产在线精品一区二区不卡 | 久久精品人人爽人人爽快 | 国产成人爱片免费观看视频 | 精品亚洲一区二区 | 国内自产拍自a免费毛片 | 深夜做爰性大片中文 | 免费一区二区三区四区五区 | 又粗又爽又色男女乱淫播放男女 | 亚洲精品视频免费 |