0

我在将变量放入数组时遇到问题。这是我的代码:

var info = new Array();
google.load("feeds", "1");

function initialize() {
  var feed = new google.feeds.Feed("http://www.ntvmsnbc.com/id/24927681/device/rss/rss.xml");
  feed.setNumEntries(6);

  feed.load(function(result) {
    if (!result.error) {
      var container = document.getElementById("feed");
      var html = '';
      for (var i = 0; i < result.feed.entries.length; i++) {
        var entry = result.feed.entries[i];
        var a = " " ;
        a += entry.title;
        info[i] = a

       html += '<p>' + entry.publishedDate + '&nbsp' + entry.title;
      }
      container.innerHTML = html;
    }
    alert(info[0]);
  });
  //alert(info[0]);
}
//alert(info[0]);
google.setOnLoadCallback(initialize);

您会看到一个名为 info 的数组。我正在尝试将 entry.title 添加到其中。你可以看到有些地方被注释掉了。我的信息[0] 是空的。我只能在函数(结果)中显示我的结果,除了它不显示任何东西,就像我从未在我的数组中放入任何东西一样。我不明白为什么。

更新:

    var info = new Array();
google.load("feeds", "1");
function initialize(cb) {
  var feed = new google.feeds.Feed("http://www.ntvmsnbc.com/id/24927681/device/rss/rss.xml");
  feed.setNumEntries(6);

  feed.load(function(result) {
    if (!result.error) {
      var container = document.getElementById("feed");
      var html = '';
      for (var i = 0; i < result.feed.entries.length; i++) {
        var entry = result.feed.entries[i]; 
       html += '<p>' + entry.publishedDate + '&nbsp' + entry.title;
        cb(entry.title);

      }
      container.innerHTML = html;
    }
  });
}
google.setOnLoadCallback(function(){
initizalize(processInfo);}
);
function processInfo(information){
    info[info.length] = information;
    alert(info[info.length]);
}

最新版本

    var info = new Array();
google.load("feeds", "1");
function initialize(cb) {
  var feed = new google.feeds.Feed("http://www.ntvmsnbc.com/id/24927681/device/rss/rss.xml");
  feed.setNumEntries(6);

  feed.load(function(result) {
    if (!result.error) {
      var container = document.getElementById("feed");
      var html = '';
      for (var i = 0; i < result.feed.entries.length; i++) {
        var entry = result.feed.entries[i];
        var a= " ";
        a += entry.title;
        info[i] = a;
       html += '<p>' + entry.publishedDate + '&nbsp' + entry.title;
      }
      container.innerHTML = html;
    }
     cb(info);
  });
}
google.setOnLoadCallback(function(){
initizalize(processInfo);}
);
function processInfo(info){
    alert(info[0]);
}   
4

3 回答 3

0

您无法info在这些点显示,因为调用feed.load()异步的,并且到那时还没有完成。

您需要在回调函数中继续进行所有处理.load,例如:

function initialize(cb) {
  feed.load(function(result) {
    ...
    cb(info);   // only call the callback once the data is loaded
  });
}

// call the above function, passing a callback handler
google.setOnLoadCallback(function() {
  initialize(processInfo);
}));

// defer all of your data processing to here
function processInfo(info) {
  ...
}
于 2012-07-23T12:43:39.663 回答
0

那是因为 AJAX 是异步的,基本上意味着它至少在运行完其余代码之前不会运行。任何依赖于定义为 AJAX 调用(或任何其他异步回调)的东西的东西都必须在该回调中,或者本身推迟到以后。

于 2012-07-23T12:44:02.770 回答
0

确保result.feed.entries.length它不为零,并且您实际上正在执行for循环。另外(但次要);info[i] = a

于 2012-07-23T12:44:43.580 回答