时间:2021-07-01 10:21:17 帮助过:23人阅读
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);
}
}
});
}
我可以非常确定obj拿到的确实是json格式的数据。但是alert一直就是undefined的,表示非常费解啊!
相同的ajax方法请求不同的php返回的json数据,很奇怪的是一个可以有值一个没有值。如下是我的ajax方法接收返回数据的处理
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);
}
}
});
}
我可以非常确定obj拿到的确实是json格式的数据。但是alert一直就是undefined的,表示非常费解啊!
这么神奇,题主你确定请求的这两个都是标准的json
数据!要都是标准的应该不会出现undefined
。你加eval
试试呢!
success:function(obj){
obj = eval("("+obj+")");
alert(obj.status);
if(obj.status == 1){
$('div[name="data-list-p"]').append(obj.html);
}
}
有没有拿到数据在chrome的console里面看一下就知道了啊
是不是两个url返回数据格式不对啊!你看看是不是json不标准
应该返回的不是 JSON
格式,而是 JSON 字符串
,转一下就可以了
无论是chrome还是firefox都能够看到返回的参数 很好确认!~
你先别急着输出.status 先输出整个obj 再看结果比较好~!
将php返回json的代码改为一样的看下
嗯。我也确信你拿的到是json
数据,但是这个obj
中确实有status
属性吗?
console.log(obj);
用这个方式在控制台看会比较方便。
var obj_json = JSON.parse(obj);
字符串变为json