我正在抓取一些数据库条目,创建一个2D数组,然后用AJAX将它们传递给js。但是当我在javascript中循环遍历数组时,这是一个“未定义”的混乱。 dbArray 的控制台日志工作正常,所以我知道PHP / AJAX正在运行。不知道我在循环中做错了什么......
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);
}
});
答案 0 :(得分:2)
我想这是失败的,因为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"? */ }
});