>웹 프론트엔드 >JS 튜토리얼 >비동기 forEach 루프에 대한 완료 콜백을 구현하는 방법은 무엇입니까?

비동기 forEach 루프에 대한 완료 콜백을 구현하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-04 13:09:01703검색

How to Implement a Completion Callback for Asynchronous forEach Loops?

비동기 forEach 콜백: 완료 콜백 구현

forEach와 같은 비동기 루프가 사용되는 시나리오에서는 모든 비동기 작업이 완료되면 콜백합니다. 이 가이드에서는 이 기능을 구현하기 위한 몇 가지 접근 방식을 제시합니다.

1. 단순 카운터 활용

이 기술은 항목이 처리될 때마다 증가하는 카운터를 사용합니다. 카운터가 총 항목 수에 도달하면 완료 콜백이 호출됩니다.

function callback () { console.log('all done'); }

var itemsProcessed = 0;

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

2. ES6 Promise 활용

Promise를 사용하면 순차적 Promise 체인을 생성하여 비동기 작업의 동기 실행을 보장할 수 있습니다.

function asyncFunction (item, cb) {
  setTimeout(() => {
    console.log('done with', item);
    cb();
  }, 100);
}

let requests = [1, 2, 3].reduce((promiseChain, item) => {
    return promiseChain.then(() => new Promise((resolve) => {
      asyncFunction(item, resolve);
    }));
}, Promise.resolve());

requests.then(() => console.log('done'))

3. 비동기 라이브러리 사용

"async"와 같은 라이브러리는 원하는 기능을 표현하기 위한 메커니즘을 제공합니다. 구체적인 구현은 선택한 라이브러리에 따라 달라집니다.

위 내용은 비동기 forEach 루프에 대한 완료 콜백을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.