Promise链式调用 终止或取消

Promise回调分两种方法,then成功,catch失败

let promise = new Promise(function(resolve, reject){
    resolve('第一次成功')
})

promise.then(function(val) {
    // 两种方法意思都代表报错,【中断下一步,直接报错
  //第一种方法
    throw new error()
  // 第二种方法
  return Promise.reject()
}).then(function(val) { console.log(
'被跳过的方法') }).catch(function(val) { console.log('返回失败') })

 

第三种方法有点粗暴,但也是目前看来可解决的可行办法

let promise = new Promise(function(resolve, reject){
    resolve('第一次成功')
})

promise.then(function(val) {
  //第三种方法
    return new Promise(()=>{})
}).catch(function(val) {
    console.log('返回失败')
}).then(function(val) {
    console.log('被跳过的方法')
})

 

前两种如果链式调用最后以失败结尾的话是可行的,如果以成功结尾就会出问题,第三种方法是直接阻断性,讲进程转到新的Promise

 

目前只想到三种方法,但本人认为这不是最好的解决办法,后续如果后小伙伴发现更好的办法可以评论哦

转载于:https://www.cnblogs.com/gqx-html/p/10967412.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值