How to get last resolved promise from a list of resolved promises in Javascript?(如何从一个已解析的承诺列表中获取最后一个已解析的承诺?)
本文介绍了如何从一个已解析的承诺列表中获取最后一个已解析的承诺?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
假设我们有承诺列表[p1,p2]
。
我想创建一个以[p1,p2]
作为参数并返回最后解析的承诺的函数,即在本例中,返回的承诺将是p2
。
动机是我要在Promise对象上实现last()方法。
const p1 = new Promise((resolve,reject)=>{
setTimeout(()=>{resolve("P1 resolved in 3 seconds")},3000)
});
const p2 = new Promise((resolve,reject)=>{
setTimeout(()=>{resolve("P2 resolved in 5 seconds")},5000)
});
Promise.race([p2,p1]).then(value=>{ console.log(value) // Both promises resolved but P2 is slower
}) // Expected output : P1 resolved in 3 seconds
Promise.last([p2,p1]).then(value=>{ console.log(value) // Both promises resolved but P2 is slower
}) // Expected output : P2 resolved in 5 second.
推荐答案
非常简单:只需使用标准Promise.all
等待所有承诺,并将它们按兑现(当兑现时)的顺序放入一个数组中,这样就可以访问最后一个值:
async function lastResult(promises) {
if (!promises.length) throw new RangeError("No last result from no promises");
const results = [];
await Promise.all(promises.map(p =>
p.then(v => {
results.push(v);
})
));
return results[results.length-1];
}
您可以调整它来以您希望的方式处理拒绝,返回任何其他(例如第一个)结果等。如果您确实只需要最后一个结果,则不需要将它们存储在数组中,而只需保留一个变量,您可以在每次承诺解析时覆盖该变量。
这篇关于如何从一个已解析的承诺列表中获取最后一个已解析的承诺?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:如何从一个已解析的承诺列表中获取最后一个已


基础教程推荐
猜你喜欢
- 什么是不使用 jQuery 的经验技术原因? 2022-01-01
- WatchKit 支持 html 吗?有没有像 UIWebview 这样的控制器? 2022-01-01
- 如何使用sencha Touch2在单页中显示列表和其他标签 2022-01-01
- jQuery File Upload - 如何识别所有文件何时上传 2022-01-01
- 如何在特定日期之前获取消息? 2022-01-01
- 如何使用 CSS 显示和隐藏 div? 2022-01-01
- 为什么我在 Vue.js 中得到 ERR_CONNECTION_TIMED_OUT? 2022-01-01
- Javascript 在多个元素上单击事件侦听器并获取目标 2022-01-01
- Node.js 有没有好的索引/搜索引擎? 2022-01-01
- 每次设置弹出窗口的焦点 2022-01-01