값 배열(예: 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의 결과를 누적하고, 마지막으로 수집된 결과를 반환합니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3