成免费的crm,久久国产精品新农夫导航新妓网,恋夜秀场全部视频安卓手机,女校花强奷在线播放A级

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

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

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

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

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

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

*ajax創建對象:   

 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 請求:

無法使用緩存文件(更新服務器上的文件或數據庫)
向服務器發送大量數據(post 沒有數據量限制)
發送包含未知字符的用戶輸入時,post 比 get 更穩定也更可靠

*ajax響應:

要獲得服務器的響應,需要使用xmlhttprequest 對象的 responsetext 或 responsexml 屬性。

responsetext:獲得字符串形式的響應數據。

document.getelementbyid("mydiv").innerhtml=xmlhttp.responsetext;

responsexml:獲得xml形式的響應數據。

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

*ajax - onreadystatechange : 

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

每當 readystate 改變時,就會觸發 onreadystatechange 事件。

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

當 readystate 等于 4 且狀態為 200 時,表示響應已就緒:

xmlhttp.onreadystatechange=function()
 {
 if (xmlhttp.readystate==4 && xmlhttp.status==200)
  {
  document.getelementbyid("mydiv").innerhtml=xmlhttp.responsetext;
  }
 }

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

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

解決方案有如下幾種:

① 在ajax發送請求前加上anyajaxobj.setrequestheader("if-modified-since", "0")。

② 在ajax發送請求前加上anyajaxobj.setrequestheader("cache-control", "no-cache")。

③ 在url后加上一個隨機數:"fresh=" + math.random();。

④ 在url后加上時間搓:"nowtime=" + new date().gettime();。

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

總結

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

相關文章