Fork me on GitHub

关于IE下的页面缓存和Ajax请求问题

ASP.NET几种清除页面缓存的方法
在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");

第二种是HTML方法

        <HEAD>
        <META HTTP-EQUIV="Pragma" CONTENT="no-cache">
        <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache">
        <META HTTP-EQUIV="Expires" CONTENT="0">
        </HEAD>   

第三种是在页面中禁用缓存
在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();

在IE下若发现ajax请求不到后台解决方法:
在原URL后加上一个随机数,让每次请求的URl都不相同就行。
如:

var urlChange = "原url"+"&"+Math.random();
$.ajax({
      url: urlChange,
      type: 'get',
      async: true,
      dataType: 'json',
      success: function (data) {
            //doSomething...
          }
      }
  });

转自:https://www.cnblogs.com/JuneZhang/archive/2010/11/23/1885538.html

posted @ 2020-07-15 10:15  madman98  阅读(113)  评论(0编辑  收藏  举报