我有一个ajax调用,它位于另一个函数内的forEach循环中。 问题是,外部函数的回调在内部循环结束之前触发 - 因此“staticItemList”在传递给回调时没有填充项目。 我该如何解决这个问题?我真的花了很多时间。感谢。
exports.buildTheList = function (parsedList, callback) {
var staticItemList = {};
parsedList.forEach(function(parsedItem) {
db.staticList.find({"_id":parsedItem.ID}).forEach(function(err, doc) {
if (!doc){
console.log("newStaticItem not found in db");
parsedDataFetcher.fetchParsedDetails(Path, function(parsedDetails){
staticItemList["_id"] = parsedItem.ID;
staticItemList[parsedItem.ID] = {
"_id": parsedItem.ID,
"type": parsedItem.type,
}
})
}else {
console.log("newStaticItem already found in db");
}
});
});
callback(staticItemList);
}
答案 0 :(得分:5)
在循环内添加一个计数器变量,并在每次异步方法完成时减少它。一旦计数器达到零,就调用回调。在伪代码中:
var counter = 0;
foreach(function() {
counter++;
doAsync(function() {
// add to list
counter--;
if (counter === 0) {
callback(list);
}
});
}
希望有所帮助。
答案 1 :(得分:1)
答案 2 :(得分:0)
AJAX是异步发生的,所以会发生什么是你的循环运行,触发所有AJAX调用,然后完成,调用你的回调。您可能需要在foreach循环中实现某种计数器,并在完成每个AJAX调用时检查它。一个已完成的AJAX调用的数量与计数器的数量相同,您将在异步函数上下文中执行回调函数。