在 JavaScript 中,有一个名为“Promise.all”的方法,它允许您并行运行一系列 Promise。然而,有时您可能想连续履行您的承诺。如果您想确保每个 Promise 依次执行,或者需要在执行下一个 Promise 时使用一个 Promise 的结果,这会很有用。
有一些您可以通过不同的方式在 JavaScript 中连续运行一系列 Promise。在本文中,我们将介绍其中的一些。
Promise.prototype.then()
串联运行 Promise 数组的一种方法是链接使用 then() 方法将它们组合在一起。该方法接受一个函数作为输入,该函数将在 Promise 完成后执行。
示例
Examples Promise.resolve(1) .then(result => { document.getElementById("result1").innerHTML = result return Promise.resolve(2); }) .then(result => { document.getElementById("result2").innerHTML = result return Promise.resolve(3); }) .then(result => { document.getElementById("result3").innerHTML = result });
登录后复制
如您所见,我们使用 then() 方法将三个 Promise 链接在一起。第一个 Promise 解析为值 1,并显示该值。第二个 Promise 解析为值 2,该值也被显示。最后,第三个 Promise 解析为值 3,并显示该值。
立即学习“Java免费学习笔记(深入)”;
因为“then”方法返回一个 Promise,所以我们可以通过这种方式将 Promise 链接在一起以创建一个系列。
for-await-of
串联运行 Promise 数组的另一种方法是使用“for-await-of”循环。此循环允许您在 for 循环内使用await 关键字。 wait 关键字暂停代码的执行,直到承诺得到履行。
示例
这是一个示例 –
Example- for-await-of async function runPromisesInSeries() { for await (const promise of [ Promise.resolve(1), Promise.resolve(2), Promise.resolve(3), ]) { const result = await promise; document.write(result); document.write("
") } } runPromisesInSeries();
登录后复制
在此示例中,我们有一个包含“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 数组?的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2689979.html