async、await用法

将下面代码复制到谷歌浏览器的开发者工具。

function getSyncTime() {
  return new Promise((resolve, reject) => {
    try {
      let startTime = new Date().getTime()
      setTimeout(() => {
        let endTime = new Date().getTime()
        let data = endTime - startTime
        resolve( data )
      }, 500)
    } catch ( err ) {
      reject( err )
    }
  })
}

async function getSyncData() {
  let time = await getSyncTime()
  let data = `endTime - startTime = ${time}`
  return data
}

async function getData() {
  let data = await getSyncData()
  console.log( data )
}

getData()
image.png

可以看出,async、await有以下特点:

  1. 最底层的await需要返回Promise对象(例如这里的最底层就是getSyncTime函数,返回的就是Promise对象)
  2. 可以让异步逻辑用同步写法实现
  3. 可以通过多层异步函数async function的同步写法代替传统的callback嵌套。
全部评论

相关推荐

10-05 23:02
东北大学 Java
我说句实话啊:那时候看三个月培训班视频,随便做个项目背点八股,都能说3 40w是侮辱价
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务