我正在测试一些代码,并使用这些数据创建了一个json文件。
问题是我在警告中得到了“对象对象,对象对象”。无数据。
我做错了什么?
代码如下:
<!DOCTYPE HTML>
<html>
<head>
<title></title>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<script>
$(document).ready(function() {
$.getJSON("appData.json",function(results){alert(results);});
});
</script>
</head>
<body>
</body>
</html>下面是appData.json的内容
[{"foo":"bar"},{"foo2":"blablabla"}]此外,index.html文件和json文件都在我的桌面上,我从那里运行它。
发布于 2012-08-12 04:18:09
请这样尝试:
$.getJSON("appData.json", function(results) {
$.each(results, function(index) {
alert(results[index].foo);
});
});发布于 2012-08-12 04:16:12
你得到了一个对象数组,数组和对象就是数据。
// v----first Object in the outer Array
alert(results[0].foo);
// ^----foo property of the first Object只是alert显示了对象的默认toString()值。
当您使用$.getJSON时,jQuery会自动将JSON文本解析为JavaScript对象。如果您想要原始的JSON,那么改为发出一个$.get请求。
如果要迭代数组,请使用for循环,或者来自jQuery或原生API的迭代方法之一。
发布于 2012-08-12 04:17:59
当警告一个对象时,它会说,[Object],如果使用火狐,你总是可以做alert(results.toSource());,但一个更好的选择是开始使用控制台(F12):
$(document).ready(function() {
$.getJSON("appData.json",function(results){
console.log(results);
});
});你可以看到整个物体及其结构。
https://stackoverflow.com/questions/11917280
复制相似问题