如何在 JavaScript 中连续运行给定的 Promise 数组?

PHPz
풀어 주다: 2023-09-24 13:25:02
앞으로
600명이 탐색했습니다.

如何在 JavaScript 中连续运行给定的 Promise 数组?

在 JavaScript 中,有一个名为“Promise.all”的方法,它允许您并行运行一系列 Promise。然而,有时您可能想连续履行您的承诺。如果您想确保每个 Promise 依次执行,或者需要在执行下一个 Promise 时使用一个 Promise 的结果,这会很有用。

有一些您可以通过不同的方式在 JavaScript 中连续运行一系列 Promise。在本文中,我们将介绍其中的一些。

Promise.prototype.then()

串联运行 Promise 数组的一种方法是链接使用 then() 方法将它们组合在一起。该方法接受一个函数作为输入,该函数将在 Promise 完成后执行。

示例



   Examples

로그인 후 복사

如您所见,我们使用 then() 方法将三个 Promise 链接在一起。第一个 Promise 解析为值 1,并显示该值。第二个 Promise 解析为值 2,该值也被显示。最后,第三个 Promise 解析为值 3,并显示该值。

因为“then”方法返回一个 Promise,所以我们可以通过这种方式将 Promise 链接在一起以创建一个系列。

for-await-of

串联运行 Promise 数组的另一种方法是使用“for-await-of”循环。此循环允许您在 for 循环内使用await 关键字。 wait 关键字暂停代码的执行,直到承诺得到履行。

示例

这是一个示例 -



   Example- for-await-of

로그인 후 복사

在此示例中,我们有一个包含“for-await-of”循环的异步函数。该循环迭代一系列 Promise。对于数组中的每个承诺,我们等待承诺得到履行。一旦履行了 Promise,就会显示该值。

使用库

如果您需要比本机 Promise API 提供的更多功能,您可以使用 Bluebird 等库或问:这些库提供了使用 Promise 的附加方法。

例如,Bluebird 提供了一种“映射”方法,允许您将值数组映射到 Promise 数组,然后等待所有值要兑现的承诺 -

const Promise = require('bluebird');

Promise.map([1, 2, 3], x => {
   return Promise.resolve(x * 2);
}).then(results => {
   console.log(results); // [2, 4, 6]
});
로그인 후 복사

结论

在本文中,我们了解了在 JavaScript 中连续运行一系列 Promise 的几种不同方法。我们已经了解了如何使用“then”方法将 Promise 链接在一起,如何使用“for-await-of”循环,以及如何使用 Bluebird 或 Q 等库。

위 내용은 如何在 JavaScript 中连续运行给定的 Promise 数组?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:tutorialspoint.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!