首页 > web前端 > js教程 > 正文

如何在 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学习者快速成长!