비동기 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!