>  기사  >  웹 프론트엔드  >  배열에서 매개변수 전달을 통해 Promise 실행 순서를 지정하는 방법은 무엇입니까?

배열에서 매개변수 전달을 통해 Promise 실행 순서를 지정하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-20 14:57:02373검색

How to Sequence Promise Execution with Parameter Passing from an Array?

배열에서 매개변수 전달을 통한 Promise의 순차적 실행

값 배열(예: myArray)이 있고 Promise를 실행해야 하는 시나리오를 생각해 보세요. 기반 함수(예: myPromise)를 순차적으로 전달하여 각 배열 요소를 매개변수로 전달합니다. Promise가 올바른 순서로 해결되도록 보장하는 "일시 중지 가능한 루프"를 어떻게 구현할 수 있습니까?

해결책: 반복적 약속 실행

순차 실행을 달성하려면 Promise Chaining의 조합을 사용할 수 있습니다. 그리고 반복적인 처리. 다음은 이 작업을 수행하는 방법을 보여주는 코드 조각입니다.

myArray.reduce(
  (p, x) =>
    p.then(() => myPromise(x)),
  Promise.resolve()
)

이 접근 방식은 축소 메서드를 활용하여 배열을 반복하고 일련의 연결된 Promise를 생성합니다. 각 Promise는 이전 Promise가 완료된 후 해결되어 원하는 실행 순서를 효과적으로 적용합니다.

비동기 함수 대안

비동기 함수를 지원하는 경우 forEachSeries를 사용하여 더 깔끔한 솔루션을 사용할 수 있습니다. 함수:

const forEachSeries = async (iterable, action) => {
  for (const x of iterable) {
    await action(x)
  }
}

forEachSeries(myArray, myPromise)

이 함수는 배열을 반복하고 각 요소에서 일시 중지하여 다음 반복을 진행하기 전에 Promise가 해결될 때까지 기다립니다.

결과 수집

Promise의 반환 값을 배열로 수집해야 하는 경우 다음과 같이 forEachSeries 함수를 수정할 수 있습니다.

const mapSeries = async (iterable, fn) => {
  const results = []

  for (const x of iterable) {
    results.push(await fn(x))
  }

  return results
}

이 함수는 배열을 반복하고 결과에 Promise의 결과를 누적합니다. 배열하고 최종적으로 수집된 결과를 반환합니다.

위 내용은 배열에서 매개변수 전달을 통해 Promise 실행 순서를 지정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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