猿问

promise多线路写法问题

 fn1().then(function(res){

    console.log(res)

    return fn2(res).then(function(res){

         console.log(res)

    },function(err){

        console.log(err)

    })

}).catch(function(res){

    return fn3(res).then(function(res){

    console.log(res)

    },function(err){

        console.log(err)

    })

})

fn1执行后根据返回结果走不同线路,成功的话return fn2,失败的话return fn3,这样写好像又开始嵌套,有没有更好的写法?


繁花如伊
浏览 410回答 2
2回答

慕村225694

可以试着改下参数function p(bool, msg) {  return new Promise(function (resolve, reject) {    setTimeout(function () {      if (bool) resolve(msg);      else reject(msg);    }, 1000)  })}p(true, 'true').then(function (res) {  console.log(res);  return p(true, 'then');}).catch(function (res) {  console.log(res);  return p(true, 'catch');}).then(function (res) {  console.log(res);}).catch(function (res) {  console.log(res)})

炎炎设计

有babel的话上async/await吧,没有的话,最多也就是拆分成子函数看起来舒服点而已
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答