关于IE下的页面缓存和Ajax请求问题
2021-01-20 21:15
标签:etc 就是 添加 代码 内容 随机 ons com zha ASP.NET几种清除页面缓存的方法 解决方法如下: 第二种是HTML方法 第三种是在页面中禁用缓存 在IE下若发现ajax请求不到后台解决方法: 转自:https://www.cnblogs.com/JuneZhang/archive/2010/11/23/1885538.html 关于IE下的页面缓存和Ajax请求问题 标签:etc 就是 添加 代码 内容 随机 ons com zha 原文地址:https://www.cnblogs.com/bemad/p/13303998.html
在asp.net中使用模式dialog时,你会发现每次打开的页面都是相同的内容,页面内容并没有刷新,这是缓存的原因造成的,
第一种是ASP.NET清除页面缓存 Response.Buffer = true;
Response.ExpiresAbsolute = System.DateTime.Now.AddSeconds(-1);
Response.Expires = 0;
Response.CacheControl = "no-cache";
Response.AddHeader("Pragma", "No-Cache");
在web开发中合理使用缓存可以有效的提高网站的性能,但是在某些场合下因为缓存的存在会带来很多的问题。
例如:因为缓存的存在会造成重复提交数据的问题,验证码图片不能正确显示的问题,等等。这个时候我们就要禁用页面缓存的功能。
我们常用的做法是发送一个“no-cache”的指令,但是实际使用过程中我们发现,这个指令对IE是有效的,但是对Firefox却没有效,这是因为,使用该指令Firefox不缓存HTTPS pages 但是还是会缓存HTTP pages ,这是Firefox的一个BUG,解决的办法很简单,就是使用no-store代替no-cache,同时发送no-store和no-cache指令
ASP.net中的处理方法,在不需要缓存的页面中添加如下代码 Response.Cache.SetCacheability(System.Web.HttpCacheability.NoCache);
Response.Cache.SetNoStore();
在原URL后加上一个随机数,让每次请求的URl都不相同就行。
如:var urlChange = "原url"+"&"+Math.random();
$.ajax({
url: urlChange,
type: ‘get‘,
async: true,
dataType: ‘json‘,
success: function (data) {
//doSomething...
}
}
});