如何从外部URL获取JSON数据?

6

我正在与一家公司合作,他们有一个隐私政策和使用条款的API。我需要创建两个不同的页面...一个用于隐私政策,另一个用于使用条款。我对此还比较陌生,感觉离成功很近。

以下是接收JSON的方式(经过编辑以保护隐私):

{"code":200,"status":"Ok","data":
    {"offset":0,"limit":20,"total":2,"target":"html_page","results":[
        {
            "id":"6",
            "title":"Privacy Policy",
            "description":"Privacy Policy",
            "html":"HTML CODE BLAH BLAH",
            "tags":["privacy"]
        },
        {
            "id":"66",
            "title":"License and TOU",
            "description":"Terms of Use",
            "html":"HTML CODE BLAH BLAH",
            "tags":["terms"]
        }]
    }
}

这是我正在使用的代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>Privacy Policy</title>
</head>
<body>
    <div id="placeholder"></div>
    <script src="http://code.jquery.com/jquery-1.7.1.min.js"></script>
    <script>
    $.getJSON('http://externalurl.com', function(external) {
        var output="<ul>";
        for (var i in external.code.offset) {
            output+="<li>" + external.html + "</li>";
        }

        output+="</ul>";
        document.getElementById("placeholder").innerHTML=output;
  });
    </script>
</body>
</html>

页面仅返回空白页。我做错了什么?

2个回答

3
$.getJSON('http://externalurl.com', function(external) {
        var output = $("<ul />");

        $.each(external.data.results, function(i, result) {
             $('<li />', {text : result.html}).appendTo(output);
        });

        $('#placeholder').html(output);
});

0

我认为应该是:

$.getJSON('http://externalurl.com', function(external) {
    var output="<ul>";
    for (var i = 0; i < external.data.results.length; i++) {
        output+="<li>" + external.data.results[i].html + "</li>";
    }

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

首先,您正在迭代错误的对象,应该是 external.data.results 而不是 external.code.offset。其次,您不能使用 for (var i in array) 迭代数组。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接