ie下jquery.getJSON的缓存问题的处理方法

前端之家收集整理的这篇文章主要介绍了ie下jquery.getJSON的缓存问题的处理方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

在项目中遇到一个问题,在火狐下,$.getJSON();请求数据一切正常,但是在IE下面,$.getJSON();只请求一次数据,第二次根本就不发送请求了,用fiddler抓取了才知道,第二次没有发送请求,改成了post就正常了

$.getJSON()存在缓存问题,如果其调用的url之前曾经调用过的话,回调函数就会直接在缓存里取得想要得值,而不是进入到后台

解决方法如下:

1、让每次调用的URL都不一样。

方法:在参数中加一个随机

复制代码代码如下:

$.getJSON("/Member/GetExercise.html",{ id: $("#Wareid").val(),isBool: loop,random:
Math.random() },function (data) });

复制代码代码如下:

$.getJSON("/Member/GetExercise.html?random=Math.random",
isBool: loop,},function (data) });

用new Date()也可以算是随机的URL

复制代码代码如下:

?random=new Date().getTime()

2、将cache设为false

复制代码代码如下:

$.ajax({ type:"GET", url:'/Member/GetExercise.html',cache:false,dataType:"json",success:function (data){ alert(data); } });

猜你在找的Json相关文章