为什么一个含有3个对象元素的数组只能访问第一个元素?

图片描述
status展开里面有三个元素
然后status[0]是我push进去的对象元素
然后status[1]status[2]就是各种undefined,为什么?

下面是完整代码,试了几遍,觉得跟变量作用域有关系,但是数组变量result是在最外层的啊,在里面push()为什么外面取不到?

function getStreamsStatus(channels) {
  var results = [];
  $.each(channels, function(index, channel) {
    var result = [];
    // result.push({ name: channel });
    $.getJSON (
      "https://api.twitch.tv/kraken/streams/" + channel,
      {
        Accept: "application/vnd.twitchtv.v5+json",
        client_id: "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
        callback: ""
      },
      function(data) {
        result.push(data);
        $.getJSON(
          data._links.channel,
          {
            Accept: "application/vnd.twitchtv.v5+json",
            client_id: "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
            callback: ""
          },
          function(channel_data) {
            result.push(channel_data);
            // console.log(result);
            // console.log(result[0]);
            // console.log(result[1]);
          });
        console.log(result);
        console.log(result[0]);
        console.log(result[1]);
      });
    results.push(result);
    // console.log(result);
    // console.log(result[0]);
    // console.log(result[1]);
  });
  return results;
}
阅读 3.7k
4 个回答

Ajax是异步过程,回调函数是在数据取回之后才执行的操作
而你的results.push(result),在数据没有取回的时候应该已经push进去了
所以你查看的时候是还没push进去数据的数组,
要等数据加载完你再console才能看得到数据
前面的Ajax嵌套也是同理

undefined也可以存进数组里,并且也有长度。

老哥…截图求截全,

好了,你用了each 那就已经开始遍历数组了

$.each(statuses, function (index, status) {
  console.log(status)
})

输出的status 就是各个object

控制台中,点击数组后显示的是实时的状态,而你打印时只有一个,后面异步来了数据填充进了数组。你在代码里输出result长度就知道

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题