在javascript中迭代json

时间:2014-03-10 04:44:54

标签: javascript json iteration

我有一个json的迭代,我无法工作。

$.post('getdatafromdatabase.php', function(data) {
    var output="<ul> START ";

    for (var i in data.results) {
        output+="<li>" + data.results[i].id + " " + data.results[i].latitude + "--" + data.results[i].longitude+"</li>";
    }

    output+=" END </ul>" + data;
    document.getElementById("bounds").innerHTML += output;
});

“START”和“END”会打印出来。在“结束”之后我打印出“数据”也可以使用,所以我知道我从数据库中获取数据,它看起来像这样:

{"results":[{"id":"1","latitude":"47.49882200000000","longitude":"19.05680300000000"},     {"id":"2","latitude":"47.49273300000000","longitude":"19.03345700000000"},{"id":"3","latitude":"47.47765200000000","longitude":"18.98942600000000"},{"id":"4","latitude":"47.47266300000000","longitude":"18.81643700000000"}]}

有人可以帮我解决这个问题。我花了很多时间在这上面,我无法弄清楚为什么我不能打印它。感谢。

3 个答案:

答案 0 :(得分:1)

使用

var data = $.parseJSON(data);

开始循环阅读之前。

答案 1 :(得分:1)

使用.ajax代替$.post

$.ajax({url:'getdatafromdatabase.php',
        type: "POST",
        data: { name: "John", location: "Boston" }}).done(function(data) {
    var output="<ul> START ";
    for (var i in data.results) {
        output+="<li>" + data.results[i].id + " " + data.results[i].latitude + "--" + data.results[i].longitude+"</li>";
    }
    output+=" END </ul>" + data;
    document.getElementById("bounds").innerHTML += output;
});

答案 2 :(得分:0)

以这种方式在javascript中迭代json:

for (var key in obj) {
  if (obj.hasOwnProperty(key)) {
    var val = obj[key];
    console.log(val);
  }
}