亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

淺析IE瀏覽器關于ajax的緩存機制

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

IE瀏覽器對于同一個URL只返回相同結果。因為,在默認情況下,IE會緩存ajax的請求結果。對于同一個URL地址,在緩存過期之前,只有第一次請求會真正發(fā)送到服務端。大多數(shù)情況下,我們使用ajax是希望實現(xiàn)局部刷新的,所以這就牽扯到一個改進的問題。

  如果想每次都獲取到最新數(shù)據(jù),我們只需保證每次傳入的URL不一樣。最簡單的方法就是通過給url拼接參數(shù)。利用math函數(shù)的random()方法生成隨機數(shù)。

  比如訪問百度www.baidu.com,我們就可以把地址寫成www.baidu.com?t=Math.random();或者?t=new Date().getTime();

  ********************************分割線**********************************

  說到這里,不妨復習一下ajax的基本用法。

*Ajax創(chuàng)建對象:   

 var xmlhttp;
 if (window.XMLHttpRequest){
  //IE7+, Firefox, Chrome, Opera, Safari
    xmlhttp = new XMLHttpRequest();
  } else{
  //IE6, IE5
    xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }  
           

*Ajax請求:

//GET請求:
xmlhttp.open("GET","test1.txt",true);
xmlhttp.send();
//POST請求:
xmlhttp.open("POST","demo_post.asp",true);
xmlhttp.send();

GET 還是 POST?

與 POST 相比,GET 更簡單也更快,并且在大部分情況下都能用。

然而,在以下情況中,請使用 POST 請求:

無法使用緩存文件(更新服務器上的文件或數(shù)據(jù)庫)
向服務器發(fā)送大量數(shù)據(jù)(POST 沒有數(shù)據(jù)量限制)
發(fā)送包含未知字符的用戶輸入時,POST 比 GET 更穩(wěn)定也更可靠

*Ajax響應:

要獲得服務器的響應,需要使用XMLHttpRequest 對象的 responseText 或 responseXML 屬性。

ResponseText:獲得字符串形式的響應數(shù)據(jù)。

document.getElementById("myDiv").innerHTML=xmlhttp.responseText;

ResponseXML:獲得XML形式的響應數(shù)據(jù)。

如果來自服務器的響應是 XML,而且需要作為 XML 對象進行解析。

*Ajax - onreadystatechange : 

當請求被發(fā)送到服務器時,我們需要執(zhí)行一些基于響應的任務。

每當 readyState 改變時,就會觸發(fā) onreadystatechange 事件。

在 onreadystatechange 事件中,我們規(guī)定當服務器響應已做好被處理的準備時所執(zhí)行的任務。

當 readyState 等于 4 且狀態(tài)為 200 時,表示響應已就緒:

xmlhttp.onreadystatechange=function()
 {
 if (xmlhttp.readyState==4 && xmlhttp.status==200)
  {
  document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
  }
 }

補充:下面看下淺談Ajax解決瀏覽器的緩存問題

Ajax能提高頁面載入速度的主要原因是通過Ajax減少了重復數(shù)據(jù)的載入,也即在載入數(shù)據(jù)的同時將數(shù)據(jù)緩存到內(nèi)存中,一旦數(shù)據(jù)被加載,只要沒有刷新頁面,這些數(shù)據(jù)就會一直被緩存在內(nèi)存中,當提交的URL與歷史的URL一致時,就不需要提交給服務器,也即不需要從服務器獲取數(shù)據(jù),雖然降低了服務器的負載,提高了用戶體驗,但不能獲取最新的數(shù)據(jù)。為了保證讀取的信息都是最新的,需要禁止其緩存功能。

解決方案有如下幾種:

① 在Ajax發(fā)送請求前加上anyAjaxObj.setRequestHeader("If-Modified-Since", "0")。

② 在Ajax發(fā)送請求前加上anyAjaxObj.setRequestHeader("Cache-Control", "no-cache")。

③ 在URL后加上一個隨機數(shù):"fresh=" + Math.random();。

④ 在URL后加上時間搓:"nowtime=" + new Date().getTime();。

⑤ 如果是使用jQuery,則用$.ajaxSetup({cache:false})。這樣頁面的所有Ajax都會執(zhí)行該語句而不需要保存緩存記錄。

總結

以上所述是小編給大家介紹的IE瀏覽器關于ajax的緩存機制,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網(wǎng)站的支持!

標簽: Ajax
相關文章:
主站蜘蛛池模板: 一级特黄特黄的大片免费 | 222在线看片免费 | 欧美一区二区三区男同 | 久久久婷婷亚洲5月97色 | 婷婷色网 | 黄 色 片在观看 | 一级黄色毛毛片 | 国产精品4p露脸在线播放 | 久久久久国产精品美女毛片 | 草逼视频网址 | 天天影视欲香欲色成人网 | 青青操精品 | 在线观看日韩一区 | 日韩一级片在线免费观看 | 精品国产一区二区三区在线观看 | 丁香亚洲综合五月天婷婷 | 91官网| 亚洲特级aaaaaa毛片 | 婷婷午夜激情 | 在线观看 日韩 | 国产在线拍小情侣国产拍拍偷 | 欧美久久亚洲精品 | 成人做爰免费看网站 | 日韩一级欧美一级毛片在线 | 国产 麻豆 欧美亚洲综合久久 | 黄色网址视频免费 | 国产亚洲视频在线 | 国产亚洲一区二区三区在线观看 | 亚洲第成色999久久网站 | 国产真实乱freesex | 中文字幕卡二和卡三的视频 | 免费人成黄页在线观看日本 | 国产三级日本三级美三级 | 91寡妇天天综合久久影院 | 亚洲日本欧美综合在线一 | 亚洲和欧美毛片久久久久 | 日韩毛片视频 | 国产在线拍揄自揄视频不卡99 | 久久99国产精品久久99果冻传媒 | 国产日韩精品欧美一区色 | 亚洲视频影院 |