jquery ajax cache的问题

<script>
function test()
        {
            $.ajax({
                type:'GET',
                url:"tt.php",
                data:"page=112",
                success:function(msg)
                {
                    alert(msg);
                }
            })    
        }
</script>
   <a οnclick="test()">test</a>
/*
ie下面只会建立一次 ajax 请求,将响应结果放在浏览器缓存里 下次调用该ajax请求时 从缓存里读取
火狐下面 每次激活事件 都会重新建立一次ajax请求
所以 ie 不能保证ajax数据的实时性 解决方式就是   cache:false
上次面试遇见这个问题了
*/

处理方法:

Ajax处理IE不更新的cache问题

在做ajax页面无刷新添加的时候,IE下遭遇Ajax缓存,因为刚开始并不知道IE有这个坏毛病,折腾好久,终于解决问题。总结一下解决办法:

在IE下用Ajax请求某一页面,通常会因为缓存的原因而返回上一次的结果,造成混乱,[即get方式时,获取数据,因发送参数和地址都一致,故IE浏览器会从缓存中取,而不会去请求服务器端,而post方式因为参数的不同,不会产生这个问题]而火狐下不会出现这种情况。

为了不受缓存影响,可以这样做:

1.IE访问策略:Internet选项--浏览历史记录--设置-- Internet 临时文件的选项改为每次访问网页时也可以

2.在AJAX请求的页面后加个随机函数,我们可以使用随机时间函数

    在javascript发送的URL后加上t=Math.random()

    例如这样:URL+"&"+"t="+Math.random();或者new Date(); 

3.在 URL 参数后加上 "?timestamp=" + new Date().getTime(); 

4.最好的方法:

    $.ajaxSetup({cache:false})


原文:http://hi.baidu.com/f51886/item/42433eca4e21b961f6c95dfb

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值