Promise 루프의 동기 실행 달성
루프 반복 중에 Promise 호출과 연결된 로깅 작업의 동기화를 어떻게 보장합니까? promiseWhile()을 사용하는 초기 접근 방식은 유망해 보이지만 적절한 실행 순서를 유지하는 데 대한 우려를 불러일으킵니다.
대신 이 작업에 대한 promise의 고유 기능을 활용하는 것이 좋습니다. 사용자 세부 정보를 가져오고 원래 응답 순서를 유지하기 위한 일련의 비동기 호출로 문제를 정의함으로써 Array.prototype.reduce()를 활용하여 플랫 .then() 체인을 구성할 수 있습니다.
해결 방법:
다음 코드는 이 접근 방식을 예시합니다.
<code class="javascript">function fetchUserDetails(arr) { return arr.reduce(function(promise, email) { return promise.then(function() { return db.getUser(email).done(function(res) { logger.log(res); }); }); }, Promise.resolve()); }</code>
이 함수는 이메일 주소 배열을 가져와 Promise를 반환합니다. Reduce() 함수는 배열을 반복하고 각 이메일에 대해 getUser 약속을 실행합니다. 결과는 done() 콜백에 동기적으로 기록됩니다.
함수 호출:
함수를 호출하려면 이메일 주소 배열(arrayOfEmailAddys)을 채우고 다음을 사용합니다.
<code class="javascript">fetchUserDetails(arrayOfEmailAddys).then(function() { console.log('all done'); });</code>
이 코드는 선형 약속 체인을 생성하여 각 약속이 순차적으로 해결되고 로깅 작업이 올바른 순서로 실행되도록 합니다.
위 내용은 순서를 유지하면서 약속 루프의 동기 실행을 달성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!