前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >async/await 写法示例

async/await 写法示例

作者头像
前端GoGoGo
发布2018-08-24 16:28:11
7620
发布2018-08-24 16:28:11
举报

async/await 让写异步代码感觉像写同步代码。async/await 并不是 ES6 的一部分,但可以通过使用 Babel 来使用它。

async/await 一般和 Prmoise 一起使用。下面的代码是一个生成 Promise 对象的工具方法。

代码语言:javascript
复制
function doTask({id, success=true,time=100}){
  return new Promise(function (resolve, reject) {
    setTimeout(function(){// 模拟异步
      var msg
      if(success) {
        msg = `thing ${id} is done`
        console.log(msg)
        resolve(msg);
      } else {
        msg = `thing ${id} failed`
        console.error(msg)
        reject(msg)
      }
    }, time)
  })
}

多个串行操作

以 3 个为例。代码如下

代码语言:javascript
复制
async function doSerialTing() {
  await doTask({id:1})
  console.log('sth')
  await doTask({id:2, time: 1000})
  await doTask({id:3})
}

doSerialTing()

输出

代码语言:javascript
复制
thing 1 is done
sth
thing 2 is done
thing 3 is done

await doTask(...) 的返回值为 Promise 中 resolve 值。

自己试下点这里

多个并行操作

以 3 个为例。代码如下

代码语言:javascript
复制
async function doParallelTing() {
  var [res1, res2, res3] = await Promise.all([
      doTask( {id:1}),
      doTask( {id:2, time: 1000 }), 
      doTask( {id:3})
  ])
  console.log(res1,res2,res3)
}

doParallelTing()

输出

代码语言:javascript
复制
thing 1 is done
thing 3 is done
thing 2 is done
thing 1 is done thing 2 is done thing 3 is done

自己试下点这里

错误处理

代码语言:javascript
复制
async function doTasks() {
  try {
     await doTask({id:1, success:false})
     await doTask({id:2})
  }catch(e) {
    console.log(`error: ${e}`)
  }
}

doTasks()

或这么写

代码语言:javascript
复制
async function doTasks() {
  await doTask({id:1, success:false})
  await doTask({id:2})
}

doTasks().catch((e)=>{
   console.log(`error: ${e}`)
})

输出

代码语言:javascript
复制
thing 1 failed
error: thing 1 failed

自己试下点这里

参考

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016.11.17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 多个串行操作
  • 多个并行操作
  • 错误处理
  • 参考
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档