我对jQuery ajax函数有疑问:

var arrayIdEq = JSON.stringify(iditem);
    $.ajax({
        type: "POST",
        url: "index.php",
        dataType : 'text',
        contentType: 'application/json; charset=utf-8',
        data: {
            arrayIdEq : arrayIdEq
        },
        success: function(answer) {
            alert(answer);
        },
        complete: function() {
        },
        error: function(jqXHR, errorText, errorThrown) {
            alert(jqXHR+" - "+errorText+" - "+errorThrown);
        }
    });


“ arrayIdEq”包含从0到7的数字或字符串“ EMPTY”。
PHP代码:

elseif(isset($_POST['arrayIdEq'])){
$answer = "my_answer";
return $answer;


请求后,成功响应到来时,会显示警报...但这是问题所在。警报包含的不是我的“ $ answer”值,而是...主页中的HTML代码!

<!DOCTYPE html>
<html lang="pl">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title> Medivia</title>
</head>
<body>
<h1>Medivia</h1>
    <form action="index.php" method="POST">
    <label>E-mail:<br><input type="text" name="mail" required></label>
    <br>
    <label>Hasło:<br><input type="password" name="pass" required></label>
    <br>
    <button name="login">Zaloguj się</button>
</form>
</body>
</html>


我不知道这里发生了什么。有人可以向我解释那里发生了什么吗?我做错了什么?

最佳答案

answer函数中的success变量将包含php脚本的完整输出。

因此,当您调用index.php并执行以下操作时:

elseif(isset($_POST['arrayIdEq'])){
  $answer = "my_answer";
  return $answer;
}


仅当从主脚本(而不是从函数内部)调用return语句时,脚本才会退出,但输出将是脚本在该点之前生成的输出。

您的脚本应该输出-而不是return-仅输出您要返回到javascript的内容。

与使用用于构建完整页面的index.php文件相比,针对ajax请求的单独脚本可能是更方便的解决方案。

10-04 22:20
查看更多