解决IE下jquery ajax无法获得最新数据的问题(IE缓存)
生活随笔
收集整理的這篇文章主要介紹了
解决IE下jquery ajax无法获得最新数据的问题(IE缓存)
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
今天修改一個(gè)bug,利用ajax查詢數(shù)據(jù),在谷歌瀏覽器下可以獲取到最新數(shù)據(jù),而在IE中獲得是舊數(shù)據(jù),無法獲得最新的數(shù)據(jù),經(jīng)查資料,才發(fā)現(xiàn)時(shí)IE緩存再作怪。
發(fā)現(xiàn)此ajax請求用的get方式,每次請求的URL一模一樣,IE瀏覽器有個(gè)特殊的地方,如果每次請求的URL一樣時(shí),就會(huì)拿出緩存中已有的數(shù)據(jù)顯示在頁面上,并不會(huì)再次去查詢數(shù)據(jù)庫,所以每次顯示的都是舊數(shù)據(jù)。
解決辦法:
那就有思路了,我們可以讓它每次請求的URL不一樣,可以加一個(gè)參數(shù),而且這個(gè)參數(shù)的值每次都不一樣,時(shí)間戳最好不過了。
?
url: '{0}/portal/articleManager/getContents?id={1}&date={2}'.format(window.baseUrl, $("#id").val(), new Date())
?
其中id是有用的參數(shù),而date參數(shù)我們不做處理就好了。
?
查資料得知,用post方式請求可以避免在這個(gè)問題,POST被認(rèn)為是一個(gè)變動(dòng)性訪問(瀏覽器認(rèn)為POST的提交,必定是有改變的)。
還有一個(gè)更簡便的方法,設(shè)置:
cache:false,前提就是此請求的cache還不存在。
總結(jié)
以上是生活随笔為你收集整理的解决IE下jquery ajax无法获得最新数据的问题(IE缓存)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: jQuery 通用表单方法
- 下一篇: 经常头皮发麻是什么情况?