时间:2021-05-28
问题出现原因:
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
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
IE浏览器对于同一个URL只返回相同结果。因为,在默认情况下,IE会缓存ajax的请求结果。对于同一个URL地址,在缓存过期之前,只有第一次请求会真正发送到服务
在vue项目里面,需要循环发送ajax请求,出现的问题就是循环结束,第一次服务器还没返回,导致数据处理错误,需要使用同步请求解决方案目前没有发现axios可以同
本文实例分析了ajax调用中ie缓存问题解决方法。分享给大家供大家参考,具体如下:ajax请求调用的过程中发现的问题:后台请求是一个简单的.aspx文件,而这个
方法一:使用pipeline 使用pipelining发送命令时,redisserver必须部分请求放到队列中(使用内存)执行完毕后一次性发送结果,在pipe
今天在写jQuery请求接口中发现一个问题: 在用AJAX发送请求中又嵌套了一个AJAX请求,发现在内层请求的success中对第一次success中的循环变