加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

IE下Ajax缓存问题的解决办法

发布时间:2020-12-15 21:06:28 所属栏目:百科 来源:网络整理
导读:今天在做一个用ajax聊天的时候,在chrome浏览器中可以,但在IE下遭遇Ajax缓存戏弄(老是给出与上一次一样的结果),因为刚开始并不知道IE有这个坏毛病,总结一下解决办法: 在IE下用Ajax请求某一页面,通常会因为缓存的原因而返回上一次的结果,造成混乱,而

今天在做一个用ajax聊天的时候,在chrome浏览器中可以,但在IE下遭遇Ajax缓存戏弄(老是给出与上一次一样的结果),因为刚开始并不知道IE有这个坏毛病,总结一下解决办法: 在IE下用Ajax请求某一页面,通常会因为缓存的原因而返回上一次的结果,造成混乱,而FF下不会出现这种情况。为了不受缓存影响,可以这样做: IE访问策略:Internet选项--浏览历史记录--设置-- Internet 临时文件的选项改为每次访问网页时也可以 1: 在AJAX请求的页面后加个随机函数,我们可以使用随机时间函数 在javascript发送的URL后加上t=Math.random() 例如这样:URL+"&"+"t="+Math.random();或者new Date(); 2: 在XMLHttpRequest发送请求之前加上XMLHttpRequest.setRequestHeader("If-Modified-Since","0") 一般情况下,这里的XMLHttpRequest不会直接使用 你应该可以找到这样的代码 XXXXX.send(YYYYYY); 那么,就把它变成 XXXXX.setRequestHeader("If-Modified-Since","0"); XXXXX.send(YYYYYY); 实践证明,两种方法都非常有效。 1、在服务端加 header("Cache-Control: no-cache,must-revalidate"); 2、在ajax发送请求前加上 xmlHttpRequest.setRequestHeader("If-Modified-Since","0"); 3、在ajax发送请求前加上 xmlHttpRequest.setRequestHeader("Cache-Control","no-cache"); 4、在 Ajax 的 URL 参数后加上 "?fresh=" + Math.random(); //当然这里参数 fresh 可以任意取了 5、第四种方法和第三种类似,在 URL 参数后加上 "?timestamp=" + new Date().getTime(); //推荐使用这种方式 6、用POST替代GET:不推荐

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读