最近在用jquery的ajax方法传递接收json数据时发现一个问题,那就是返回的data数据,有时候能够直接做为json数据使用,可有时候又不行。查了些资料,解释以下:javascript
$.ajax({
url: ajaxurl,
type: "POST",
success: function(data){
//假设返回的json数据里有status及info2个属性
//有时候能够直接ajaxobj.status或者ajaxobj["status"]去访问
//但有时候,却要经过eval()或者 $.parsejson();才能够经过ajaxobj.status访问,并且这种状况下,须要是complete而不是success
ajaxobj=eval("("+data+")");
//或者$.parsejson()
//var ajaxobj = $.parsejson(data);
if(ajaxobj.status=="0")
{
alert("请登录.");
}
else if(ajaxobj.status=="1")//未绑定微博
{
alert(ajaxobj.info);
}
return true;
},
error:function(ajaxobj)
{
if(ajaxobj.responseText!='')
alert(ajaxobj.responseText);
}
});
先说明第一种状况:
可以直接 data.属性名访问的状况,服务器端代码必定是直接return的一个常量字符串。
什么是常量字符串呢,常量字符串就是指直接用“”组成的字符串,没有定义String 变量直接把一串“”print到前台的状况,就能够直接data.属性名访问,并且jquery端只要写success就能够拿到。
下面是形成要eval而且不能进入success的缘由:
这种状况是由于服务器端向外print的时候是一个String对象,一般此类问题在个人代码里是由于后台json比较复杂,在组织的时候我用到了StringBuffer,而后最后print的时候print的是StringBuffer对象的toString,因此就至关于print了一个String对象
这种状况下jquery的ajax方法就不会进入success方法,只能用complete接收,而且想要解析data里的json数据的话,必须对data.responseText进行eval ()或者 $.parsejson();
除此两点,还有须要注意的是,若是你使用的是jq1.4,那么他对json的格式有着更严格的要求,全部的key和属性都要用双引号标注起来,虽然key不用双引号原生的js是容许的,可是jq1.4彷佛有这个要求。
以上是我我的的想法跟理解,如有不一样看法欢迎指教.java