• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

php 搞代码 3年前 (2022-01-23) 12次浏览 已收录 0个评论
文章目录[隐藏]

相同的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属性吗?

%本文@来源gao@!dai!ma.com搞$$代^@码!网搞代gaodaima码


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

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

字符串变为json


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:jquery获取服务端的json数据问题

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址