关于resolve、reject、all、race的使用
代码如下(示例):
// resolve,reject,all,race // resolve == then,reject == catch let promise = new Promise((resolve, reject) => { reject(2222) }) promise.then(response => { console.log('成功') console.log(response) }).catch(error => { console.log('失败') console.log(error) }) // 链式 function promise1(status){ return new Promise((resolve, reject) => { if(status) { console.log('第1个promise成功'); resolve('第1个promise返回数据成功'); // axios } if(!status) { console.log('第1个promise失败'); reject('第1个promise返回数据失败') } }) } function promise2(status){ return new Promise((resolve, reject) => { if(status) { console.log('第2个promise成功'); resolve('第2个promise返回数据成功') } if(!status) { console.log('第2个promise失败'); reject('第2个promise返回数据失败') } }) } function promise3(status){ return new Promise((resolve, reject) => { if(status) { console.log('第3个promise成功'); resolve('第3个promise返回数据成功') } if(!status) { console.log('第3个promise失败'); reject('第3个promise返回数据失败') } }) } function promise4(status){ return new Promise((resolve, reject) => { if(status) { console.log('第4个promise成功'); resolve('第4个promise返回数据成功') } if(!status) { console.log('第4个promise失败'); reject('第4个promise返回数据失败') } }) } promise1(true) .then(response => { // 第1个 console.log(response) // 返回参数,判断是否执行第2个promise return promise2(true) }) .then(response => { // 第2个 console.log(response) return promise4(true) }) .then(response => { console.log(response) }) .catch(error => { console.log(error) }) // all方法,数组内有promise必须全部成功(全部返回resolve),才会执行then回调,只要有一个是返回(reject)不成功,就会执行catch Promise.all([promise1(true), promise2(true), promise3(true)]).then(response => { console.log('全部调用成功'); }).catch(error => { console.log('有些可能失败了'); }) // race是赛跑的意思,数组中谁的结果获取的快就执行谁的结果 Promise.race([promise1(false), promise2(true), promise3(true)]).then(response => { console.log('成功'); }).catch(error => { console.log('失败了'); })
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。