promise的异步链式调用

场景:  淘米  干净的米下锅  蒸米饭  吃米饭 ;这几个步骤是一个接着一个执行, 也就是只有前面的做完后, 才会去做后面的. 并且每一步都需要用一部分时间去执行.

 

 1 function deal(task, time) {
 2     return new Promise((resolve, reject) => {  //每次都返回一个新的promise对象, 
 3         console.log("开始" + task);
 4         setTimeout(() => {
 5             console.log(task + "完成了")
 6             resolve();
 7         }, time)
 8     })
 9 }
10 
11 // 执行后会每隔一秒显示 淘米  米下锅  蒸米饭  吃米饭
12 deal("淘米", 1000).then(()=>{
13    return deal("米下锅", 1000)  //每次返回新的promise对象
14 }).then(()=>{                  //then参数注册两个函数,第一个函数对应上个promise的resolve ,第二个函数对应reject. 各层执行完才能执行下层
15    return deal("蒸米饭",1000)
16 }).then(() =>{
17    return deal("吃米饭",100)
18 })

 处理错误: catch能够抓住错误,catch的位置可以放到最后;

deal("淘米", 1000).then(()=>{
   return deal("米下锅", 1000)
}).then(()=>{
   // return deal("蒸米饭",1000)
    throw new Error("电饭锅坏了") //此处抛出错误,如果没有注册下一个then的reject函数,catch会接住,并且不会执行后面的代码
}).then(() =>{
   return deal("吃米饭",100)
})
    .catch(function (err) {
    console.log(err)
})

 

  

posted @ 2019-04-13 13:12  当当和瓶瓶  阅读(508)  评论(0编辑  收藏  举报