Undefined variable error when parsing json

Posted by Ben Shelock on Stack Overflow See other posts from Stack Overflow or by Ben Shelock
Published on 2010-06-03T02:17:29Z Indexed on 2010/06/03 2:24 UTC
Read the original article Hit count: 324

Filed under:
|
|

I'm trying to parse the json grabbed from here. Basically what I do is iterate over the items, sort them, then display them. But I get an error saying data.data.children[i] is undefined.

I can't think why it's doing it though?

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>';
    }
}

© Stack Overflow or respective owner

Related posts about JavaScript

Related posts about JSON