如何解决AJAX 的缓存

解决AJAX 的缓存的方法

1、在ajax发送请求前加上 anyAjaxObj.setRequestHeader("If-Modified-Since","0");

2、在ajax发送请求前加上 anyAjaxObj.setRequestHeader("Cache-Control","no-cache");

3、在 Ajax 的 URL 参数后加上  "?fresh=" + Math.random()

4、第五种方法和第四种类似,在 URL 参数后加上  "?timestamp=" + new Date().getTime();

5、如果是使用jQuery,直接这样就可以了 $.ajaxSetup({cache:false}) 。这样页面的所有ajax都会执行这条语句就是不需要保存缓存记录。

6、用POST替代GET

以下主要描述如何解决Jquery ajax的缓存问题。


      在使用jquery进行ajax操作时,如果Get请求的参数不变化,而且IE浏览器设置缓存不是每次访问网页时(IE工具->internet选项->浏览历史记录下的设置->检查所存网页的较新版本),则可能会出现程序不经过后台,直接从浏览器缓存里读数据的情况。

可以有三种解决方法:
1、在请求的参数后面加上时间,如:
[javascript]  view plain  copy
  1. $.ajax({  
  2.     type : "get",  
  3.     url : "http://search.json?t="+new Date(),  
  4.     dataType : "json",  
  5.     success : function(json) {  
  6.     }  
  7. });  
这样由于每次请求的参数有所不同,程序不会从浏览器里面读取缓存。

2、 在ajax请求时候加上cache:false的参数,如:
[javascript]  view plain  copy
  1. $.ajax({  
  2.     type : "get",  
  3.     url : "http://search.json",  
  4.     dataType : "json",  
  5.     cache:false,  
  6.     success : function(json) {  
  7.     }  
  8. });  
cache设置为 false 将不会从浏览器缓存中加载请求信息。

3、将ajax请求类型改为post,如:
[javascript]  view plain  copy
  1. $.ajax({  
  2.    type : "post",  
  3.    url : "http://search.json",  
  4.    dataType : "json",  
  5.    success : function(json) {  
  6.    }  
  7. });  
请求类型改为post, 将不会从浏览器缓存中加载请求信息。

备注:
①GET请求,浏览器认为是等幂的,就是一个相同的URL只有一个结果[相同是指整个URL字符串完全匹配],所以第二次访问的时候如果URL字符串没
变化,浏览器直接使用第一次访问的结果。
②POST请求,浏览器则认为是一个变动性访问(浏览器认为POST的提交必定是有改变的),所以每次都是重新发送请求。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值