是php json_encode&;AJAX破坏了我的数组


is php json_encode & AJAX breaking my array?

我正在获取一些数据库条目,创建一个2D数组,然后用AJAX将它们传递给js。但是,当我用javascript循环遍历数组时,它是一个"未定义"的混乱。dbArray的控制台日志运行良好,所以我知道PHP/AAJAX正在运行。不确定我在循环中做错了什么。。。

PHP('load-words.PHP):

$query = mysql_query("
SELECT * FROM words 
ORDER BY RAND() 
LIMIT 50
") or die(mysql_error()); 
$dbArray = array(); 
while ($row = mysql_fetch_assoc($query)) {
    $word_phrase = stripslashes($row['word_phrase']);
    $description = stripslashes($row['description']);
    // construct a 2D array containing each word and description
    $dbArray[] = array($word_phrase,$description);      
};
echo json_encode($dbArray);

Javascript:

$.ajax({
    url: 'func/load-words.php',
    success: function(dbArray) {
        console.log(dbArray);
        var items = "<ul>";
        for (var i in dbArray) {
            items += "<li><a href='#'><b>" + dbArray[i][0] + ' : ' + dbArray[i][1] + "</a></li>";
        }
        items += "</ul>";
        div = $('#dbArray');
        div.html(items);
    }
});

我想这是失败的,因为jQuery将AJAX响应解释为字符串,因为PHP没有输出JSON头,AJAX也没有规定JSON。这很容易测试:

$.ajax({
    url: 'func/load-words.php',
    success: function(dbArray) { alert(typeof dbArray); /* "string"? */ }
});

尝试

$.ajax({
    url: 'func/load-words.php',
    dataType: 'json', //<-- now we explicitly expect JSON
    success: function(dbArray) { alert(typeof dbArray); /* "object"? */ }
});