博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jquery ajax cache的问题
阅读量:7244 次
发布时间:2019-06-29

本文共 789 字,大约阅读时间需要 2 分钟。

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方式因为参数的不同,不会产生这个问题]而FF下不会出现这种情况。为了不受缓存影响,可以这样做:

 

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

 

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

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

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

 

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

 最好的方法:

 $.ajaxSetup({cache:false})

转载地址:http://omybm.baihongyu.com/

你可能感兴趣的文章
Swift-JSON Encode && Decode
查看>>
(效果五)js获取客户端ip地址及浏览器信息
查看>>
XAML中的空格、换行、Tab
查看>>
Python解析XML
查看>>
第43条:返回零长度的数组或者集合,而不是null
查看>>
初识numpy的多维数组对象ndarray
查看>>
java代码随机数100个,10个一输出显示======
查看>>
初始化代码块
查看>>
函数参数自动解包
查看>>
门诊医嘱与收费相关的表
查看>>
sql优化方案
查看>>
图片合并
查看>>
HTML5 本地存储 localStorage、sessionStorage 的遍历、存储大小限制处理
查看>>
PHP 操作数据库乱码 以及调试
查看>>
01-Nginx配置参数优化
查看>>
html5-新增表单的小结details summary
查看>>
AFN实现文件上传
查看>>
嵌入式开发之zynq---Zynq PS侧sd驱动
查看>>
web html 防盗链
查看>>
WCF,WebAPI,WCFREST和WebService的区别
查看>>