在 JavaScript 中,有一个名为“Promise.all”的方法,它允许您并行运行一系列 Promise。然而,有时您可能想连续履行您的承诺。如果您想确保每个 Promise 依次执行,或者需要在执行下一个 Promise 时使用一个 Promise 的结果,这会很有用。
有一些您可以通过不同的方式在 JavaScript 中连续运行一系列 Promise。在本文中,我们将介绍其中的一些。
Promise.prototype.then()
串联运行 Promise 数组的一种方法是链接使用 then() 方法将它们组合在一起。该方法接受一个函数作为输入,该函数将在 Promise 完成后执行。
示例
<html> <head> <title>Examples</title> </head> <body> <div id="result1"></div> <div id="result2"></div> <div id="result3"></div> <script> 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 }); </script> </body> </html>
如您所见,我们使用 then() 方法将三个 Promise 链接在一起。第一个 Promise 解析为值 1,并显示该值。第二个 Promise 解析为值 2,该值也被显示。最后,第三个 Promise 解析为值 3,并显示该值。
因为“then”方法返回一个 Promise,所以我们可以通过这种方式将 Promise 链接在一起以创建一个系列。
for-await-of
串联运行 Promise 数组的另一种方法是使用“for-await-of”循环。此循环允许您在 for 循环内使用await 关键字。 wait 关键字暂停代码的执行,直到承诺得到履行。
示例
这是一个示例 -
<html> <head> <title>Example- for-await-of</title> </head> <body> <script> 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("<br>") } } runPromisesInSeries(); </script> </body> </html>
在此示例中,我们有一个包含“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 等库。