等待内部带有承诺的 forEach 完成

Posted

技术标签:

【中文标题】等待内部带有承诺的 forEach 完成【英文标题】:Wait for forEach with a promise inside to finish 【发布时间】:2019-05-31 13:50:21 【问题描述】:

我在等待我的 forEach 循环完成时遇到了问题,该循环内部有一个承诺。我找不到任何真正的解决方案,这会使脚本等到最后,然后再继续执行。我无法使 someFunction 同步。

makeTree: function (arr) 
    arr.forEach(function (resource) 
        someModule.someFunction(resource).then(function ()  //a Promise
            //do something with the resource that has been modified with someFunction
        );
    );
    // do something after the loop finishes

【问题讨论】:

你在用 angularjs 吗? 【参考方案1】:

使用map() 代替forEach() 创建一个promise 数组,然后使用Promise.all()

let promiseArr = arr.map(function (resource) 
    // return the promise to array
    return someModule.someFunction(resource).then(function (res)  //a Promise
        //do something with the resource that has been modified with someFunction
        return res;
    )
);

Promise.all(promiseArr).then(function(resultsArray)
   // do something after the loop finishes
).catch(function(err)
   // do something when any of the promises in array are rejected
)

【讨论】:

非常感谢您的回答,我也有同样的疑问,我不想处理包或复杂的事情。这是对这些情况的最佳回应,非常简单而精彩。再次,谢谢。问候 简单明了的阅读+维护:感谢您的解决方案! 如果我的函数没有返回任何东西,则不适合我【参考方案2】:

试试这个,

makeTree: function (arr) 
   var promises = [];
   arr.forEach(function(resource) 
      promises.push(someModule.someFunction(resource));
   );
   Promise.all(promises).then(function(responses) 
      // responses will come as array of them
      // do something after everything finishes
   ).catch(function(reason) 
      // catch all the errors
      console.log(reason);
   );

您可以通过简单的示例参考此link 以了解有关Promise.all 的更多信息。

【讨论】:

以上是关于等待内部带有承诺的 forEach 完成的主要内容,如果未能解决你的问题,请参考以下文章

等待循环中调用的所有承诺完成

带有多个猫鼬查找的foreach循环后的javascript承诺

NodeJS:等待所有带有 Promises 的 foreach 完成,但从未真正完成

带有等待和承诺的 useMutation 问题

使 angular.forEach 在转到下一个对象后等待承诺

等待 onMounted() 完成内部测试