首页 >web前端 >js教程 >如何在ForEach循环内异步处理后执行回调函数?

如何在ForEach循环内异步处理后执行回调函数?

Susan Sarandon
Susan Sarandon原创
2024-11-04 15:10:02284浏览

How to Execute a Callback Function After Asynchronous Processing within a ForEach Loop?

异步迭代处理后回调完成

问题陈述:

给定一个元素数组,我们如何调用forEach 循环中的所有异步处理完成后的回调函数?

解决方案 1:基于计数器的方法

  • 在每个异步回调中增加一个计数器。
  • 当计数器达到元素总数时执行“done”回调。
<code class="javascript">function callback () { console.log('all done'); }

var itemsProcessed = 0;

[1, 2, 3].forEach((item, index, array) => {
  asyncFunction(item, () => {
    itemsProcessed++;
    if(itemsProcessed === array.length) {
      callback();
    }
  });
});</code>

解决方案 2:基于 Promise 的方法

同步执行:

  • 链式promise使用reduce()和Promise.resolve()保证同步执行。
<code class="javascript">let requests = [1, 2, 3].reduce((promiseChain, item) => {
  return promiseChain.then(() => new Promise((resolve) => {
    asyncFunction(item, resolve);
  }));
}, Promise.resolve());

requests.then(() => console.log('done'));</code>

异步执行:

  • 使用map()创建一个promise数组。
  • 当所有promise都完成时,使用Promise.all()调用“done”回调已解决。
<code class="javascript">let requests = [1, 2, 3].map((item) => {
  return new Promise((resolve) => {
    asyncFunction(item, resolve);
  });
});

Promise.all(requests).then(() => console.log('done'));</code>

解决方案 3:异步库使用

  • 利用 async 等库来简化异步编程模式。
  • 请参阅库提供的回调完成机制的具体文档。

以上是如何在ForEach循环内异步处理后执行回调函数?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn