> 웹 프론트엔드 > JS 튜토리얼 > 약속 작업으로 동기 루프 실행을 보장하는 방법은 무엇입니까?

약속 작업으로 동기 루프 실행을 보장하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-11-03 00:13:29
원래의
1073명이 탐색했습니다.

How to Ensure Synchronous Loop Execution with Promise Operations?

프로미스로 루프 조정

문제 설명

루프가 동기식으로 반복되어 각 반복의 Promise와 후속 로깅 작업(logger.log(res))이 올바른지 확인하세요. order?

해결책

Eschewing PromiseWhile

promiseWhile 함수는 Promise를 사용한 반복을 용이하게 할 수 있지만 체인 실행 순서

직렬화를 위해 Reduce 사용

원하는 순서를 유지하려면 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>
로그인 후 복사

샘플 사용법

<code class="javascript">// Compose an array of email addresses
var arrayOfEmailAddys = [...];

fetchUserDetails(arrayOfEmailAddys).then(function() {
    console.log('all done');
});</code>
로그인 후 복사

이점

이 접근 방식은 promiseWhile 메소드에 추가 변수 및 조건 함수가 필요합니다. 또한 코드를 단순화하고 약속 실행의 올바른 순서를 보장합니다.

위 내용은 약속 작업으로 동기 루프 실행을 보장하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿