Ajax与IE6缓存问题解决方案
今天,有同事发现相关业务数据修改后,在IE6下还是显示修改前的值。但在其他浏览器和IE7、IE8下,没有这个问题。
原因:用ajax请求时,如果出现重复的URL,浏览器不会向服务器发送请求,而是根据之前相同的URL请求结果返回。原因就在于之前的请求及结果已经保存在了
缓存里,如果遇到相同URL时,结果是直接从缓存里取得。解决办法:
1、设置IE6中工具-internet选项-Internet临时文件-设置-检查每次网页的较新版本-设置为每次访问此页时检查。
2、在IE发送ajax数据时,发送一个随机时间戳。即只要让每次请求的URL不一样就可以了,比如每次请求时在URL中加上时间的毫秒数或随机数(newDate().getTime()或者Math.Random()
)。
另外,网上还有很多解决方法:
1.送请求前加上
XMLHttpRequest.setRequestHeader("If-Modified-Since","0")
或者用post方法提交
2.服务器端禁用缓存(只是禁止了服务端缓存,不能禁止ajax缓存)
.
response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", 0);以上说的都对,但有一个更简单的办法,就是ajax请求时,设缓存为false
$.ajax({
url: 'tStrategyBase.do?method=checkStrategyStates&id='+id,
cache:false,
dataType: 'html',
success: function(data){
后边的代码省略。cache:是否缓存,其实就是在URL加随机数
相关推荐
结束数据方法的参数,该如何定义?-- 集合为自定义实体类中的结合属性,有几个实体类,改变下标就行了。<input id="add" type="button" value="新增visitor&quo