>  기사  >  웹 프론트엔드  >  JavaScript에서 Promise를 반복할 때 동기 로깅을 달성하는 방법은 무엇입니까?

JavaScript에서 Promise를 반복할 때 동기 로깅을 달성하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-26 21:43:02428검색

How to Achieve Synchronous Logging When Iterating Through Promises in JavaScript?

동기화를 통한 Promise 호출 반복

일반적인 시나리오에서는 실행 순서가 유지되는지 확인하기 위해 API 요청과 같은 일련의 Promise 호출을 반복하는 작업이 포함됩니다. . 블루버드는 promiseWhile 기능을 통해 솔루션을 제공합니다. 그러나 루프 내에서 logger.log(res) 호출 순서에 대한 우려가 있습니다.

제안된 솔루션

promiseWhile을 사용하는 대신 다음 접근 방식을 고려하세요.

<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>

이 코드:

  1. 약속 배열 생성: 이메일 주소 배열(arr)을 허용하고 각 이메일을 기반으로 일련의 약속을 구성합니다.
  2. Reduce를 사용한 직렬 실행: Promise를 순차적으로 실행하기 위해 Array.prototype.reduce를 활용합니다.
  3. 순서 보장: then과 Promise를 연결함으로써, 이는 이전 Promise가 해결된 후에만 logger.log(res)가 호출되도록 보장합니다.

사용 예

이메일 주소 배열을 사용하여 fetchUserDetails 함수를 호출합니다.

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

fetchUserDetails(arrayOfEmailAddys).then(function() {
    console.log('all done');
});</code>

이 접근 방식을 사용하면 재귀, 외부 카운터 및 복잡한 조건 기능이 필요하지 않으면서 원하는 logger.log(res) 호출 동기화를 유지합니다.

위 내용은 JavaScript에서 Promise를 반복할 때 동기 로깅을 달성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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