[英]ajax response data is undefined
我对ajax发布有问题,这里是我的脚本
function postad(actionurl) {
if (requestRunning) return false ;
if (! $("#editadform").valid()) {
validator.focusInvalid();
return false ;
}
$('#ajxsave').show() ;
requestRunning = true ;
var postData = $('#editadform').serializeArray();
$.ajax(
{
url : actionurl,
type: "POST",
data : postData,
success:function(data, textStatus, jqXHR)
{
$('#diverrors').html(data.errors) ;
$('#divalerts').html(data.alerts) ;
if (data.status=='success') { alert(data.status);
$('#siteid').val(data.siteid) ;
if ($('#adimager').val())
$('#divlmsg').html(data.alertimage) ;
$('#editadform').submit() ;
} else {
$('#ajxsave').hide() ;
}
},
error: function(jqXHR, textStatus, errorThrown)
{
$('#ajxsave').hide() ;
},
complete: function() {
requestRunning = false;
}
});
$('.btn').blur() // remove focus
return false ;
}
这适用于if (textStatus=='success') {
但是当操作失败时, alert(data.status)
显示为Undefined。
使用FireBug,我可以看到数据已正确返回。 为什么data.status为“未定义”?
如果您未在jQuery中指定$.ajax()
调用的dataType
字段,则会将响应的格式设置为纯文本。 代码的一种解决方法是将dataType: "JSON"
包含在$.ajax()
参数中,或者在success
函数中,使用以下方法将纯文本响应解析为JSON对象:
data = JSON.parse(data); // You can now access the different fields of your JSON object
更新:
是的,我在操作URL中没有
status
字段,如何在PHP代码中添加数据状态字段?
创建旨在返回JSON数据的PHP脚本时,您首先需要构建一个数组,然后将其编码为JSON。
因此,假设您有一个PHP脚本成功执行并生成了一些数据,这些数据被放入$data
变量中,或者失败了,那么可以采用以下样式:
<?php
// ^^ Do your PHP processing here
if($success) { // Your PHP script was successful?
$response = array("status" => "success!", "response" => $data);
echo json_encode($response);
}
else {
$reponse = array("status" => "fail", "message" => "something went wrong...");
echo json_encode($response);
}
?>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.