jQuery.getJSON不返回结果的原因分析
jQuery.getJSON不返回结果是因为缓存问题,同一个请求地址因为有缓存,所以不会发送请求,也就没有任何返回数据了。
jQuery.getJSON不返回结果的解决办法
1.让每次调用的url都不一样
可以通过在参数中加一个随机数或时间节点解决。
例子一:
jQuery.getJSON("$!/s.ashx", {Name:"john",random:Math.random()}, function(responseText){} )
例子二:
"xxx.aspx?randID="+Math.random
例子三:
"xxx.aspx?randID="+ escape(new Date())
2.将cache设为False
$.ajax不缓存版:
$.ajax({ type:"GET" url:'test.html' , cache:false, dataType:"html", success:function(msg){ alert(msg); } });
3.在labels.html文件的顶部加入以下声明:
<META HTTP-EQUIV="Pragma" CONTENT="no-cache"> <META HTTP-EQUIV="Expires" CONTENT="-1">
4.load函数不仅可以调用HTML,也可以调用script,比如labels.php,可以在php文件里使用header函数:
<?php header("Cache-Control: no-cache, must-revalidate"); ?>
5.使用post代替get方法:
使用Post方式需注意:
设置header的Context-Type为application/x-www-form-urlencode确保服务器知道实体中有参数变量. 通常使用XmlHttpRequest对象的SetRequestHeader("Context-Type","application/x-www- form-urlencoded;")。
xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
参数是名/值一一对应的键值对,每对值用&号隔开.如 var name=abc&sex=man&age=18,注意var name=update.php?abc&sex=man&age=18以及var name=?abc&sex=man&age=18的写法都是错误的;
参数在Send(参数)方法中发送,例: xmlHttp.send(name); 如果是get方式,直接 xmlHttp.send(null)
服务器端请求参数区分Get与Post。如果是get方式则$username = $_GET["username"]; 如果是post方式,则$username = $_POST["username"];
6.在服务端加 header("Cache-Control: no-cache, must-reva lidate");
7.在ajax发送请求前加上 xmlHttpRequest.setRequestHeader("If-Modified-Since","0");
8.在ajax发送请求前加上 xmlHttpRequest.setRequestHeader("Cache-Control","no-cache");
以上介绍的8中方法,可以单独使用。