zoukankan      html  css  js  c++  java
  • ie浏览器下,get请求缓存问题

    1 使用get请求数据

    1)Java代码
    $.getJSON("sortShow!sortShow?time="+new Date().getTime(),function(){});
    
    开始我是直接这样写的
    
    Java代码
    $.getJSON("sortShow!sortShow,function(){});
    
    所以刷新的时候IE 会显示上次的缓存,因此你必须提交新的数据,所以在后面加了个时间参数,即使你的后台没设置这个参数,但也不会报错。
    此时IE会重新向后台发出请求,类似的还有 math.random这个函数可以用。
    2)设置cache:false属性,防止ie缓存

    2 使用POST请求数据,可以防止ie缓存

    3 在做ajax页面无刷新添加的时候,IE下遭遇Ajax缓存,因为刚开始并不知道IE有这个坏毛病,折腾好久,终于解决问题。 总结一下解决办法: 在IE下用Ajax请求某一页面,通常会因为缓存的原因而返回上一次的结果,造成混乱,
    即get方式时,获取数据,因发送参数和地址都一致,故IE浏览器会从缓存中取,而不会去请求服务器端,
    而post方式因为参数的不同,不会产生这个问题]而FF下不会出现这种情况。为了不受缓存影响,可以这样做: IE访问策略: Internet选项--浏览历史记录--设置-- Internet 临时文件的选项改为每次访问网页时也可以
    在AJAX请求的页面后加个随机函数,我们可以使用随机时间函数 在javascript发送的URL后加上 t=Math.random() 例如这样:
    URL+"&"+"t="+Math.random();//或者new Date(); 在 URL 参数后加上 "?timestamp=" + new Date().getTime(); 最好的方法: $.ajaxSetup({cache:false}) 这样页面中所有的ajax请求时,都执行这个。就不必改已经完成的N个接口


  • 相关阅读:
    js格式化输出json对象
    webpack打包优化
    设置了responseType:Blob之后,如果返回json错误信息,如果获取?
    Webpack打包之后[-webkit-box-orient: vertical]样式丢失
    如果axios请求失败,如何获取后端接口返回的状态码及错误信息
    查看端口被占用情况
    用python编写简单爬虫
    python下载指定页面的所有图片
    Vue路由懒加载原理及实现
    PnpWebpackPlugin解析
  • 原文地址:https://www.cnblogs.com/whm-163/p/5520359.html
Copyright © 2011-2022 走看看