Jquery ajax方法解析返回的json数据

最近在用jquery的ajax方法传递接收json数据时发现一个问题,那就是返回的data数据,有时候可以直接作为json数据使用,可有时候又不行。查了些资料,解释如下:

[javascript]  view plain copy
  1. $.ajax({   
  2.         url: ajaxurl,  
  3.         type: "POST",  
  4.         success: function(data){  
  5.             //假设返回的json数据里有status及info2个属性  
  6.             //有时候可以直接ajaxobj.status或者ajaxobj["status"]去访问    
  7.             //但有时候,却要通过eval()或者 $.parsejson();才可以通过ajaxobj.status访问,而且这种情况下,需要是complete而不是success  
  8.             ajaxobj=eval("("+data+")");  
  9.             //或者$.parsejson()  
  10.             //var ajaxobj = $.parsejson(data);  
  11.             if(ajaxobj.status=="0")  
  12.             {  
  13.                 alert("请登陆.");  
  14.             }  
  15.             else if(ajaxobj.status=="1")//未绑定微博  
  16.             {  
  17.                 alert(ajaxobj.info);  
  18.             }  
  19.             return true;  
  20.         },  
  21.         error:function(ajaxobj)  
  22.         {  
  23.                     if(ajaxobj.responseText!='')  
  24.                     alert(ajaxobj.responseText);  
  25.         }  
  26.     });  
先说明第一种情况:  
    能够直接 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似乎有这个要求。

以上是我个人的想法跟理解,若有不同见解欢迎指教.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值