ie发送ajax请求返回上一次结果的解决方法
程序员文章站
2022-06-29 12:30:35
问题出现原因: 1. ie下面只会建立一次 ajax 请求,将响应结果放在浏览器缓存里 下次调用该ajax请求时 从缓存里读取 get方式时,获取数据,因发送参数和地址都一...
问题出现原因:
1. ie下面只会建立一次 ajax 请求,将响应结果放在浏览器缓存里 下次调用该ajax请求时 从缓存里读取
get方式时,获取数据,因发送参数和地址都一致,故ie浏览器会从缓存中取,而不会去请求服务器端,而post方式因为参数的不同,不会产生这个问题
2. 火狐下面 每次激活事件 都会重新建立一次ajax请求
解决方法:
1: 在ajax请求的页面后加个随机函数,我们可以使用随机时间函数
在javascript发送的url后加上t=math.random()
例如这样:url+"&"+"t="+math.random();或者new date(); 在 url 参数后加上 "?timestamp=" + new date().gettime();
2.
$.ajax({
type: "post",
async:false, // 设置同步方式
cache:false,//缓存
url: url,
data:data,
success:function(data){
//成功返回值后的操作
}
});
解决方式就是 cache:false
1. ie下面只会建立一次 ajax 请求,将响应结果放在浏览器缓存里 下次调用该ajax请求时 从缓存里读取
get方式时,获取数据,因发送参数和地址都一致,故ie浏览器会从缓存中取,而不会去请求服务器端,而post方式因为参数的不同,不会产生这个问题
2. 火狐下面 每次激活事件 都会重新建立一次ajax请求
解决方法:
1: 在ajax请求的页面后加个随机函数,我们可以使用随机时间函数
在javascript发送的url后加上t=math.random()
例如这样:url+"&"+"t="+math.random();或者new date(); 在 url 参数后加上 "?timestamp=" + new date().gettime();
2.
复制代码 代码如下:
$.ajax({
type: "post",
async:false, // 设置同步方式
cache:false,//缓存
url: url,
data:data,
success:function(data){
//成功返回值后的操作
}
});
解决方式就是 cache:false