首页 >后端开发 >php教程 >jquery获取服务端的json数据问题

jquery获取服务端的json数据问题

WBOY
WBOY原创
2016-09-08 08:44:041067浏览

相同的ajax方法请求不同的php返回的json数据,很奇怪的是一个可以有值一个没有值。如下是我的ajax方法接收返回数据的处理

<code>function getUpList(_url, _u, _p){
    $.ajax({
        type:"GET",
        data:$.param({uid:_u, page:_p}),
        url:_url,
        dataType:'json',
        success:function(obj){
            alert(obj.status);
            if(obj.status == 1){
                $('div[name="data-list-p"]').append(obj.html);
            }
        }
    });
}</code>

我可以非常确定obj拿到的确实是json格式的数据。但是alert一直就是undefined的,表示非常费解啊!

回复内容:

相同的ajax方法请求不同的php返回的json数据,很奇怪的是一个可以有值一个没有值。如下是我的ajax方法接收返回数据的处理

<code>function getUpList(_url, _u, _p){
    $.ajax({
        type:"GET",
        data:$.param({uid:_u, page:_p}),
        url:_url,
        dataType:'json',
        success:function(obj){
            alert(obj.status);
            if(obj.status == 1){
                $('div[name="data-list-p"]').append(obj.html);
            }
        }
    });
}</code>

我可以非常确定obj拿到的确实是json格式的数据。但是alert一直就是undefined的,表示非常费解啊!

这么神奇,题主你确定请求的这两个都是标准的json数据!要都是标准的应该不会出现undefined。你加eval试试呢!

<code>success:function(obj){
    obj = eval("("+obj+")");
    alert(obj.status);
    if(obj.status == 1){
        $('div[name="data-list-p"]').append(obj.html);
    }
}</code>

有没有拿到数据在chrome的console里面看一下就知道了啊

是不是两个url返回数据格式不对啊!你看看是不是json不标准

应该返回的不是 JSON 格式,而是 JSON 字符串,转一下就可以了

无论是chrome还是firefox都能够看到返回的参数 很好确认!~
你先别急着输出.status 先输出整个obj 再看结果比较好~!

将php返回json的代码改为一样的看下

嗯。我也确信你拿的到是json数据,但是这个obj中确实有status属性吗?


console.log(obj); 用这个方式在控制台看会比较方便。

<code class="javascript">var obj_json =  JSON.parse(obj);</code>

字符串变为json

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn