Jquery Ajax错误处理失败

时间:2013-08-13 20:27:49

标签: php jquery ajax

我正在尝试处理从php脚本发送的错误。这是我的代码:

<script>
$(document).ready(function() {
    $('#signUpForm').submit(function() {
        $.ajax({
            type: 'POST',
            url: "process.php",
            data: $("#signUpForm").serialize(),
            success: function(data) {
                if ((data == "Incorect email format.") || (data == "Username must be between 6-32 signs and only include 0-9, A-Z   characters.") || (data == "Password must be between 8-32 signs and only include 0-9, A-Z characters.") || (data == "Passwords do not match.") || (data == "Username is taken, please try another one.")) {
                    $('#errors').show();
                    $('#errors').html(data);
                } else {
                    window.location.href = "http://localhost:8888";
                }
            }
        });
        return false;
    });
});
 </script>

Firebug显示已发送响应,但未显示错误。哪里可能有问题?谢谢。

4 个答案:

答案 0 :(得分:1)

使用这样的代码,我会说最可能的原因是字符串是一个字符或两个字符。尝试在console.log(data)语句前面加上if,以确切了解您要比较的内容。

我建议以稍微不同的格式返回错误,以便更容易避免这样的问题。例如,如果您让服务器返回一些JSON,例如:

{
    "status": 1,
    "errorMessage": "Incorrect email format."
}

然后您可以测试非零状态代码,而不必确保整个字符串完全正确。

答案 1 :(得分:1)

因此,根据我们在评论中的讨论,您从服务器以JSON格式发回新响应,以下是如何呈现这些错误:

假设您的回复是以下内容(始终在{} {}}等网站上验证您的JSON响应:

[{"status":"1","data":"Incorrect email format."},{"status":"2","data":"Username must be min 6 signs and only include 0-9, A-Z characters."},{"status":"3","data":"Password must be min 8 signs and only include 0-9, A-Z characters."}]

现在,如果您在成功函数中获得此响应,那么您可以在html上呈现它们:

success: function (data) {
    if (data) {
        $.each(data, function (index, obj) {
            $('#error').append('<div>' + obj.data + '</div>');
        });
    }
}

以下是显示此操作的this

答案 2 :(得分:0)

使用警报(数据)显示您确切找回哪些数据并查看您是否输入了拼写错误,或者像Jemery建议的那样使用json!这比比较所有字符串容易。

一个例子:

  $('#signUpForm').submit(function() {
    $.ajax({
    type: 'POST',
    url: "process.php",
    data: $("#signUpForm").serialize(),
    dataType: 'json',
    success: function (errorstatus) {
      if (errorstatus.status >= 1) {
       $('#errors').html(errorstatus.data);
      }
      else {
           window.location.href = "http://localhost:8888";
      }
    }
    });
  }

在PHP中只需:

$errorstatus = array(
  'status' => $status,
  'data' => $data
);

echo json_encode($errorstatus);

答案 3 :(得分:-1)

正如@RaphaelDDL所说,尝试使用console.log(数据)来查看php脚本中的内容。 但是如果你能够编辑process.php,我建议返回一个错误代码并将消息存储在你的js代码中,而不是返回一个完整的字符串。我的意思是:

success: function(data) {
    if (data) {
        var error = "";
        switch (data) {
            case 1 : error = "Custom error msg 1"; break;
            case 2 : error = "Custom error msg 2"; break;
            case 3 : error = "Custom error msg 3"; break;
            ...
        }
        $('#errors').show();
        $('#errors').html(error);
    } else {
        ...
    }
}

你的php脚本:

$error_code = 0;
...
if ($some_value !== $valid_value) {
    $error_code = 1; 
}
...
die($error_code);

使用die()执行此操作是确保不向js脚本发送任何其他字符的唯一方法。