關(guān)于Ajax Get請求在IE下存在緩存問題

起源

同一份代碼在chrome和ie下出現(xiàn)不同的結(jié)果,具體表現(xiàn)為:在ie下保存操作后,頁面依然顯示為未勾選狀態(tài)。

思考

最初的時候一直思考是否是代碼問題,一度在IE下debug整塊代碼,無果。后來觀察了下三個請求均為get請求,于是轉(zhuǎn)而思考,是否是因為get請求在ie下會有緩存問題。

解釋

在IE下用Ajax請求某一頁面,通常會因為緩存的原因而返回上一次的結(jié)果,造成混亂。

  1. get方式時,獲取數(shù)據(jù),因發(fā)送參數(shù)和地址都一致,故IE瀏覽器會從緩存中取,而不會去請求服務(wù)器端,
  2. post方式因為參數(shù)的不同,不會產(chǎn)生這個問題。

為了不受緩存影響,可以這樣做:

在AJAX請求的頁面后加個隨機函數(shù),我們可以使用隨機時間函數(shù)
在javascript發(fā)送的URL后加上 t=Math.random()

例如這樣:

URL+"&"+"t="+Math.random();//或者new Date(); 
在 URL 參數(shù)后加上"?timestamp=" + new Date().getTime(); 

或者在請求參數(shù)data中添加:

data: {
                _t: new Date().valueOf() //加時間戳
                //_t: Math.random() 加隨機數(shù)
            },

示例

  $.ajax({
            type: "get",
            dataType:"json",
            url: "$!{rc.contextPath}/parkledVerb/loadVerbData?id="+id,
            data: {
                _t: new Date().valueOf() //加時間戳
                //_t: Math.random() 加隨機數(shù)
            },
            async: false,
            success: function (data) {
                ···
        });
最好的方法:
$.ajaxSetup({cache:false}) 

這樣頁面中所有的ajax請求時,都執(zhí)行這個。就不必改已經(jīng)完成的N個接口。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML標準。 注意:講述HT...
    kismetajun閱讀 28,803評論 1 45
  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補...
    _Yfling閱讀 14,124評論 1 92
  • ??2005 年,Jesse James Garrett 發(fā)表了一篇在線文章,題為“Ajax: A new App...
    霜天曉閱讀 942評論 0 1
  • 前端開發(fā)面試知識點大綱: HTML&CSS: 對Web標準的理解、瀏覽器內(nèi)核差異、兼容性、hack、CSS基本功:...
    秀才JaneBook閱讀 2,770評論 0 25
  • 【轉(zhuǎn)載】CSDN - 張林blog http://blog.csdn.net/XIAOZHUXMEN/articl...
    竿牘閱讀 3,588評論 1 14

友情鏈接更多精彩內(nèi)容