博客
关于我
异步编程--Promise其他方法
阅读量:326 次
发布时间:2019-03-03

本文共 1113 字,大约阅读时间需要 3 分钟。

1.Promise-all

Promise.all方法用于并行处理多个Promise任务。其接受一个可迭代对象(如数组),其中包含多个Promise。当这些Promise中的所有任务都完成后,整体Promise才会完成。如果有任何一个Promise失败,整个Promise也会失败。

Promise.all(iterable)方法的参数是可迭代对象,返回的结果是一个新的Promise。该Promise的状态取决于迭代器中所有Promise的状态。如果所有Promise都成功完成,返回的结果数组包含这些Promise的结果;如果有任何一个Promise失败,整个Promise也会失败。

例如:

let p1 = new Promise((resolve, reject) => { setTimeout(() => { console.log(1) resolve(10); }, 2000); }); let p2 = new Promise((resolve, reject) => { setTimeout(() => { console.log(2) resolve(20); }, 3000); }); Promise.all([p1, p2]).then(arr => { console.log(3, arr); });

上述代码输出结果为:

2.Promise-race

Promise.race方法用于并行处理多个Promise任务,但与Promise.all不同,它会在第一个任务完成时立即执行回调函数。无论第一个任务是否成功,整个Promise的状态都会根据第一个任务的状态来决定。

Promise.race(iterable)方法的参数同样是一个可迭代对象,返回的结果是一个新的Promise。该Promise的状态与迭代器中第一个任务的状态有关。如果第一个任务成功完成,返回的结果是该任务的结果;如果第一个任务失败,整个Promise也会失败。

例如:

let p1 = new Promise((resolve, reject) => { setTimeout(() => { console.log(1) resolve(10); }, 2000); }); let p2 = new Promise((resolve, reject) => { setTimeout(() => { console.log(2) resolve(20); }, 1000); }); Promise.race([p1, p2]).then(arr => { console.log(3, arr); });

转载地址:http://edvm.baihongyu.com/

你可能感兴趣的文章
Oracle监听配置、数据库实例配置等
查看>>
Oracle系列:安装Oracle RAC数据库(二)
查看>>
oracle系统 介绍,ORACLE数据库管理系统介绍
查看>>
oracle获取数据库表、字段、注释、约束等
查看>>
Oracle计划将ZGC项目提交给OpenJDK
查看>>
Oracle闪回技术(Flashback)
查看>>
oracle零碎要点---ip地址问题,服务问题,系统默认密码问题
查看>>
oracle零碎要点---oracle em的web访问地址忘了
查看>>
Oracle零碎要点---多表联合查询,收集数据库基本资料
查看>>
Oracle静默安装
查看>>
Oracle面试题:Oracle中truncate和delete的区别
查看>>
ThreadLocal线程内部存储类
查看>>
thinkphp 常用SQL执行语句总结
查看>>
Oracle:ORA-00911: 无效字符
查看>>
Text-to-Image with Diffusion models的巅峰之作:深入解读 DALL·E 2
查看>>
TCP基本入门-简单认识一下什么是TCP
查看>>
tableviewcell 中使用autolayout自适应高度
查看>>
Orcale表被锁
查看>>
svn访问报错500
查看>>
org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned
查看>>