別の関数内にある forEach ループ内に ajax 呼び出しがあります。問題は、内側のループが終了する前に外側の関数のコールバックが起動することです。そのため、コールバックに渡されたときに「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);
}