做一個項目用到Ajax,開始覺得挺好,后來發現一個問題,例如刪除一項,恢復之后就不能再接著刪除,
必須要等一段時間,后來知道是IE緩存的問題
AJAX緩存頁面是一個剛接觸AJAX的人一定會遇到的問題,造成這個問題的關鍵性人物又是Ie...
在網上找了好多資料后,總結一下
1:在AJAX請求的頁面后加個隨機函數,我們可以使用隨機時間函數
在javascript發送的URL后加上t=Math.random()
當然,不是直接把t=Math.random()拷貝到URL后面,應該像這樣:URL+"&"+"t="+Math.random();
2:在XMLHttpRequest發送請求之前加上XMLHttpRequest.setRequestHeader("If-Modified-Since","0")
一般情況下,這里的XMLHttpRequest不會直接使用
你應該可以找到這樣的代碼
XXXXX.send(YYYYYY);
那么,就把它變成
XXXXX.setRequestHeader("If-Modified-Since","0");
XXXXX.send(YYYYYY);
第二種方法感覺挺好
ajax 清除緩存的兩種方法
第一種:
模板上加上
<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">
第二種:
url加上隨機數變量
[AJAX介紹]
Ajax是使用客戶端腳本與Web服務器交換數據的Web應用開發方法。Web頁面不用打斷交互流程進行重新加裁,就可以動態地更新。使用Ajax,用戶可以創建接近本地桌面應用的直接、高可用、更豐富、更動態的Web用戶界面。
異步JavaScript和XML(AJAX)不是什么新技術,而是使用幾種現有技術——包括級聯樣式表(CSS)、JavaScript、XHTML、XML和可擴展樣式語言轉換(XSLT),開發外觀及操作類似桌面軟件的Web應用軟件。
[AJAX執行原理]
一個Ajax交互從一個稱為XMLHttpRequest的JavaScript對象開始。如同名字所暗示的,它允許一個客戶端腳本來執行HTTP請求,并且將會解析一個XML格式的服務器響應。Ajax處理過程中的第一步是創建一個XMLHttpRequest實例。使用HTTP方法(GET或POST)來處理請求,并將目標URL設置到XMLHttpRequest對象上。
當你發送HTTP請求,你不希望瀏覽器掛起并等待服務器的響應,取而代之的是,你希望通過頁面繼續響應用戶的界面交互,并在服務器響應真正到達后處理它們。要完成它,你可以向XMLHttpRequest注冊一個回調函數,并異步地派發XMLHttpRequest請求。控制權馬上就被返回到瀏覽器,當服務器響應到達時,回調函數將會被調用。
[AJAX實際應用]
1. 初始化Ajax
Ajax實際上就是調用了XMLHttpRequest對象,那么首先我們的就必須調用這個對象,我們構建一個初始化Ajax的函數:
代碼如下:
/**
* 初始化一個xmlhttp對象
*/
function InitAjax()
{
var ajax=false;
新聞熱點
疑難解答
圖片精選