Ajax与IE6缓存问题及解决方法

发布时间:2021-11-25 22:50:12 作者:柒染
来源:亿速云 阅读:145

本篇文章给大家分享的是有关Ajax与IE6缓存问题及解决方法,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

向大家简单介绍一下Ajax与IE6缓存问题,用ajax请求时,如果出现重复的URL,浏览器不会向服务器发送请求,而是根据之前相同的URL请求结果返回。

Ajax与IE6缓存问题

今天,有同事发现相关业务数据修改后,在IE6下还是显示修改前的值。但在其他浏览器和IE7、IE8下,没有这个问题。

原因:用ajax请求时,如果出现重复的URL,浏览器不会向服务器发送请求,而是根据之前相同的URL请求结果返回。原因就在于之前的请求及结果已经保存在了 缓存里,如果遇到相同URL时,结果是直接从缓存里取得。

解决办法:

1、设置IE6中工具-internet选项-Internet临时文件-设置-检查每次网页的较新版本-设置为每次访问此页时检查。

2、在IE发送ajax数据时,发送一个随机时间戳。即只要让每次请求的URL不一样就可以了,比如每次请求时在URL中加上时间的毫秒数或随机数(new Date().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与IE6缓存问题及解决方法,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。

推荐阅读:
  1. 【ajax】Ajax $().load() 禁用缓存
  2. jquery怎样处理ajax缓存问题

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

ajax ie6

上一篇:Ajax具体指的是什么

下一篇:C#如何实现基于Socket套接字的网络通信封装

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》