小編給大家分享一下如何解決IE8下Ajax緩存問題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括慶元網(wǎng)站建設(shè)、慶元網(wǎng)站制作、慶元網(wǎng)頁制作以及慶元網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,慶元網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到慶元省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
Ajax簡介
AJAX即“Asynchronous Javascript And XML”(異步JavaScript和XML),是指一種創(chuàng)建交互式網(wǎng)頁應(yīng)用的網(wǎng)頁開發(fā)技術(shù)。
AJAX = 異步 JavaScript和XML(標(biāo)準(zhǔn)通用標(biāo)記語言的子集)。
AJAX 是一種用于創(chuàng)建快速動(dòng)態(tài)網(wǎng)頁的技術(shù)。
通過在后臺與服務(wù)器進(jìn)行少量數(shù)據(jù)交換,AJAX 可以使網(wǎng)頁實(shí)現(xiàn)異步更新。這意味著可以在不重新加載整個(gè)網(wǎng)頁的情況下,對網(wǎng)頁的某部分進(jìn)行更新。
下面的代碼,在其他瀏覽器都是正常的,但是在IE8中出現(xiàn)詭異問題。
$.ajax({ url:dataUrl, data:encodeURI(currentjsonform), dataType:'JSON', success:function(item){ debugger; .... } });
經(jīng)過仔細(xì)排查,尼瑪是 IE8 存在的 ajax 緩存問題。尼瑪,執(zhí)行到這里,實(shí)際上,并沒有訪問我們后臺的代碼,而是使用了以前緩存的結(jié)果,后臺進(jìn)行調(diào)試時(shí),沒有反應(yīng),才發(fā)現(xiàn)是這個(gè)問題?。。?!IE8肯跌啊。
但是 奇怪的是,很多地方都是這樣的代碼,為什么只有這里被緩存,而其他地方?jīng)]有緩存問題呢?
解決方法:
1.
$.ajaxSetup({ cache: false });
2. 參數(shù)加上屬性:cache:false
$.ajax({ url:dataUrl, data:encodeURI(currentjsonform), dataType:'JSON', cache:false, success:function(item){ debugger; .... } });
3. 還可以在 url 后面加上時(shí)間戳等方法。
教訓(xùn):
程序員真是應(yīng)該:過馬路要兩邊看!
不要太相信默認(rèn)值,需要什么屬性,一定要指明。所以最好每次都指明: cache:false,或者每個(gè)js 頁面保證在最開始處執(zhí)行一次:
$.ajaxSetup({ cache: false });
其實(shí) 路徑帶上時(shí)間戳或者隨機(jī)數(shù)的方法,有時(shí)并不可靠!可能是瀏覽器會(huì)忽略它吧。反正IE8多次遇到 url帶時(shí)間戳失效的情況。
以上是“如何解決IE8下Ajax緩存問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!