为什么我不能通过ajax将回调数组从PHP传递给jquery


Why cant I pass a callback array from PHP to jquery via ajax?

我有一个大文件,但在调试问题时,我将其缩小,以消除所有外部内容。基本上,我最终得到了这个.php文件:

<?php 
if (isset($_POST['val'])) {
        header("Content-type: application/json; charset=utf-8");
        echo json_encode(array("The first string", "first"));
    }
?>
 <script type="text/javascript" src="javascript/jquery.js"></script>
 <script type="text/javascript">
    $.ajax({
        type: 'POST',
        url: 'other',
        data: {val: 'text'},
        contentType: "application/json",
        dataType: 'json',
        success: function(result) {
            console.log(result);
            alert(result);
        },
        error: function(err) {
            console.log(err);
            alert('Error -> ' + err);
        }
    });
 </script>

在原始代码中,我在不同的文件中有PHP和Javascript,所以请不要告诉我将PHP继承为像<?php ?>这样的Javascript,我刚刚研究了很多材料,很多人都这样建议。

在这个脚本中,会触发一个错误函数。当我研究这个问题时,我发现,当传递无效的json时,它会被触发。这是我在警报框中得到的内容:Error -> [object Object],这是我从控制台中得到的信息:

uncaught exception: out of memory <unknown>
Object { readyState: 4, getResponseHeader: .ajax/v.getResponseHeader(), getAllResponseHeaders: .ajax/v.getAllResponseHeaders(), setRequestHeader: .ajax/v.setRequestHeader(), overrideMimeType: .ajax/v.overrideMimeType(), statusCode: .ajax/v.statusCode(), abort: .ajax/v.abort(), state: .Deferred/d.state(), always: .Deferred/d.always(), then: .Deferred/d.then(), 11 more… }

如果我将dataType更改为html,并删除contentType,我将执行success函数。它通过了这个:

["The first string","first"]
<script type="text/javascript" src="javascript/jquery.js"></script>
<script type="text/javascript">
$.ajax({
        type: 'POST',

以及页面的其余代码。

我需要收到一个json。为什么这个东西不起作用?为什么我没有收到json?

p.S。你可能会注意到,我在url的末尾没有.php。。。我有一个.htaccess文件,它会删除它,所以这不是问题所在。我禁用了它,并将脚本与.php一起使用,但没有任何变化。PHP代码已经执行,但我没有得到正确的回调。。。

在回显json后尝试添加一个出口,这样就不会在ajax调用中返回下面的html。

<?
if (isset($_POST['val'])) {
        header("Content-type: application/json; charset=utf-8");
        echo json_encode(array("The first string", "first"));
        exit; // add exit here so html below is not also returned
    }
?>