Ajax簡介
AJAX即“Asynchronous Javascript And XML”(非同步JavaScript和XML),是指一種建立互動式網頁應用的網頁開發技術。
AJAX = 非同步 JavaScript和XML(標準通用標記語言 (SGML)的子集)。
AJAX 是一種用於建立快速動態網頁的技術。
通過在後台與伺服器進行少量資料交換,AJAX 可以使網頁實現非同步更新。這意味著可以在不重新載入整個網頁的情況下,對網頁的某部分進行更新。
下面的代碼,在其他瀏覽器都是正常的,但是在IE8中出現詭異問題。
$.ajax({url:dataUrl,data:encodeURI(currentjsonform),dataType:'JSON',success:function(item){debugger;....}});
經過仔細排查,尼瑪是 IE8 存在的 ajax 緩衝問題。尼瑪,執行到這裡,實際上,並沒有訪問我們背景代碼,而是使用了以前緩衝的結果,後台進行調試時,沒有反應,才發現是這個問題!!!!IE8肯跌啊。
但是 奇怪的是,很多地方都是這樣的代碼,為什麼只有這裡被緩衝,而其他地方沒有緩衝問題呢?
解決方案:
1.
$.ajaxSetup({ cache: false });
2. 參數加上屬性:cache:false
$.ajax({url:dataUrl,data:encodeURI(currentjsonform),dataType:'JSON',cache:false,success:function(item){debugger;....}});
3. 還可以在 url 後面加上時間戳記等方法。
教訓:
程式員真是應該:過馬路要兩邊看!
不要太相信預設值,需要什麼屬性,一定要指明。所以最好每次都指明: cache:false,或者每個js 頁面保證在最開始處執行一次:
$.ajaxSetup({ cache: false });
其實 路徑帶上時間戳記或者隨機數的方法,有時並不可靠!可能是瀏覽器會忽略它吧。反正IE8多次遇到 url帶時間戳記失效的情況。
以上所述是小編給大家介紹的IE8下Ajax緩衝問題,希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對雲棲社區網站的支援!