ie下使用ajax缓存问题

前端之家收集整理的这篇文章主要介绍了ie下使用ajax缓存问题前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

在做一个消息管理的功能时,用到了ajax的get方法

$.get('/member/message/delete/?ids[]='+a+'&type='+obj,function(data){
if(data) {
if(data==1){
document.location.reload();
}else{
alert('删除失败!');
}
}
})

在火狐和谷歌下测试均正常,但在ie下,功能是没问题,但每次执行该方法之后都要等一段时间才能继续执行。想到是缓存的问题,于是将方法改为:

$.get('/member/message/delete/?ids[]='+a+'&type='+obj+‘&t=’+Math.random(),function(data){
if(data) {
if(data==1){
document.location.reload();
}else{
alert('删除失败!');
}
}
})

问题解决

防止ie缓存问题的方法

1:在AJAX请求的页面后加个随机函数,我们可以使用随机时间函数 在javascript发送的URL后加上t=Math.random() 当然,不是直接把t=Math.random()拷贝到URL后面,应该像这样:URL+"&"+"t="+Math.random();

2:在XMLHttpRequest发送请求之前加上XMLHttpRequest.setRequestHeader("If-Modified-Since","0") 一般情况下,这里的XMLHttpRequest不会直接使用 你应该可以找到这样的代码 XXXXX.send(YYYYYY); 那么,就把它变成 XXXXX.setRequestHeader("If-Modified-Since","0"); XXXXX.send(YYYYYY);

ajax 清除缓存的两种方法

第一种: 模板上加上 <Meta HTTP-EQUIV="pragma" CONTENT="no-cache"> <Meta HTTP-EQUIV="Cache-Control" CONTENT="no-cache,must-revalidate"> <Meta HTTP-EQUIV="expires" CONTENT="Wed,26 Feb 1997 08:21:57 GMT">

第二种: url加上随机数变量

猜你在找的Ajax相关文章