"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 배열에서 매개변수 전달을 통해 Promise 실행 순서를 지정하는 방법은 무엇입니까?

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

2024년 11월 18일에 게시됨
검색:986

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가 완료된 후 해결되어 원하는 실행 순서를 효과적으로 적용합니다.

비동기 함수 대안

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

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의 결과를 누적하고, 마지막으로 수집된 결과를 반환합니다.

릴리스 선언문 이 글은 1729407377에서 재인쇄되었습니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3