内部forEach循环内部的ajax,在内部回调触发后完成

时间:2012-11-26 20:29:09

标签: javascript ajax node.js

我有一个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);
     }

3 个答案:

答案 0 :(得分:5)

在循环内添加一个计数器变量,并在每次异步方法完成时减少它。一旦计数器达到零,就调用回调。在伪代码中:

 var counter = 0;
 foreach(function() {
     counter++;
     doAsync(function() {
           // add to list

           counter--;
           if (counter === 0) {
               callback(list);
           }
     });
 }

希望有所帮助。

答案 1 :(得分:1)

我会看到像道场承诺all这样的东西。从手册:

  

dojo/promise/all是一个承担多个承诺的函数   返回一个新的承诺,当所有承诺都已履行时履行   满足。

该页面上的示例演示了如何做到所需。

答案 2 :(得分:0)

AJAX是异步发生的,所以会发生什么是你的循环运行,触发所有AJAX调用,然后完成,调用你的回调。您可能需要在foreach循环中实现某种计数器,并在完成每个AJAX调用时检查它。一个已完成的AJAX调用的数量与计数器的数量相同,您将在异步函数上下文中执行回调函数。