我正在尝试解析从here抓取的json。基本上我所做的是遍历项目,对它们进行排序,然后显示它们。但我收到错误data.data.children[i] is undefined
。
我想不出为什么会这样做?
var json = 'http://www.reddit.com/reddits/mine/.json';
GM_xmlhttpRequest({
method: "GET",
url: json,
onload: reddits
});
function reddits(response){
var txt = response.responseText;
var data;
var suggested = document.getElementById('suggested-reddits');
if(window.JSON && JSON.parse){
data = JSON.parse(txt);
}
else{
data = eval("("+txt+")");
}
suggested.innerHTML += '<span>reddits you\'re subscribed to </span> <ul id="rsub"></ul>';
GM_addStyle('#rsub{width: 500px;}');
var reddits = new Array();
var rsub = document.getElementById('rsub');
for(i = 0; i <= data.data.children.length; i++){
var r = data.data.children[i].data.display_name;
reddits.push(r);
}
sort(reddits);
for(i = 0; i <= reddits.length; i++){
rsub.innerHTML += '<li><a href="#" onclick="set_sr_name(this); return false">' + reddits[i] + '</a></li>';
}
}
答案 0 :(得分:2)
for(i = 0; i <= data.data.children.length; i++){
var r = data.data.children[i].data.display_name;
reddits.push(r);
}
明确的问题在for语句中。将i <= data.data.children.length
更改为i < data.data.children.length
。注意不平等的变化。
由于Javascript中的数组是0索引的,因此i = data.data.children.length
处的元素不存在。
你应该为reddits.length
循环做同样的事情。