下面的代码出现了这个问题:http://jsfiddle.net/double0seven/z3Yr4/
var feedurl = "https://itunes.apple.com/nl/rss/topsongs/limit=25/xml";
var j, i, x;
$.getJSON("http://ajax.googleapis.com/ajax/services/feed/load?q=" + feedurl + "&v=1.0&num=-1&callback=?", function(data) {
for (j = 0; j < 21; j += 1) {
qt = j + ". " + data.responseData.feed.entries[j].title.replace('#', '');
console.log(qt);
li = $("<li/>").html(qt).appendTo('#ul1');
$.getJSON("http://gdata.youtube.com/feeds/api/videos?q=" + qt + "&v=2&start-index=1&max-results=1&orderby=relevance&format=5&alt=jsonc&callback=?", (function(el) {
return function(videoFeed) {
for (i = 0; i < videoFeed.data.items.length; i += 1) {
entry = videoFeed.data.items[i];
track = qt;
var liid = liid += 1;
el.empty();
el.addClass("item");
el.attr('id', i);
el.attr('ytid', entry.id);
el.attr('titel', entry.title);
newdiv = $(document.createElement("div"));
newdiv.addClass("mod");
newdiv.append("<h3>" + qt + "<br></h3>");
el.append(newdiv);
}
};
}(li)));
}
})下面是它需要做的事情:
不知道为什么,我想需要和另一个结局有关。但不确定。我在网上到处搜索,但毫无头绪。
谢谢你的帮助。
发布于 2014-04-02 15:16:53
正在发生的情况是,qt引用在您的外部循环中每次迭代都会被更新,当对Youtube API的第一个Ajax响应完成时,外部循环已经到达终点。
您必须用每个内部Ajax-请求存储每个qt引用,以便请求更新相关的LI。
最简单的方法是创建一个函数,该函数返回使用外部函数的参数的函数:
var renderLi = function (qt, el) {
return function(videoFeed) {
...
};
};
...
$.getJSON("http://gdata.youtube.com/feeds/api/videos?q=" + qt + "&v=2&start-index=1&max-results=1&orderby=relevance&format=5&alt=jsonc&callback=?", renderLi(qt, li));http://jsfiddle.net/z3Yr4/24/
https://stackoverflow.com/questions/22815187
复制相似问题