在使用ajax进行前后台交互的时候,经常会遇到到前台js取不到服务器响应数据的情况,这时候也许你已经跨域了,最常用也是最有效的解决跨域问题的方法就是使用JsonP。 ajax的getJSON 函数。
具体使用方法说明:
前端js
$.getJSON('test.php?action=test&jsoncallback=?&test_id='+test_id,function(data){
alert(data);
});
用jsoncallback作为服务器端支持的标准jsonp参数,而每次执行这个方法都会用时间戳生成一个唯一的全局函数名,替换这个“?”,这个细节被封装到黑盒里,使用者不必了解,可以像普通的ajax请求一样,用匿名的回调函数作为最末尾的参数(这是jquery强调的风格);
ajax请求不会更新缓存,用jsoncallback当做一个随机字符串来解决ajax请求不会更新缓存的问题。
服务器php
function test()
{
……
$testtime= $_GET['jsoncallback'];
echo $testtime.'('.$testtitle.')';
}
如果需要输出一个数组对象可以使用json处理下,然后前台进行获取并处理显示。
阻止浏览器默认的事件(比如<a href=""></a> 默认跳转等)
e.preventDefault();