原文地址=> 6 Reasons Why JavaScript’s Async/Await Blows Promises Away (Tutorial)

Async/await 是建立在 Promises上的,不能被使用在普通回调以及节点回调

Async/await 和 Promises 很像,不阻塞

Async/await 代码看起来像同步代码。

语法

假设函数getJSON返回值是 Promise,并且 Promise resolves 有一些JSON 对象。我们只想调用它并且记录该JSON并且返回完成。

使用Promise

const makeRequest = () =>getJSON().then(data => {console.log(data)return "done"})makeRequest()

使用Async

const makeRequest = async() => {console.log(await getJSON)return "done"
}makeRequest()

区别

  1. 在函数前有一个关键字asyncawait关键字只能在使用async定义的函数中使用。任何一个async函数都会隐式返回一个promise,并且promise resolve 的值就是 return 返回的值 (例子中是”done”)
  2. 不能在函数开头使用await

有哪些好处

  1. 简洁的代码

使用async函数可以让代码简洁很多,不需要像Promise一样需要些then

  1. 错误处理

Promise 中不能自定义使用 try/catch 进行错误捕获,但是在 Async/await 中可以像处理同步代码处理错误

const makeRequest = () => {try {getJSON().then(result => {// this parse may failconst data = JSON.parse(result)console.log(data)})// uncomment this block to handle asynchronous errors// .catch((err) => {//   console.log(err)// })} catch (err) {console.log(err)}
}

Async/await

const makeRequest = async () => {try {// this parse may failconst data = JSON.parse(await getJSON())console.log(data)} catch (err) {console.log(err)}
}
  1. 条件语句

条件语句也和错误捕获是一样的,在 Async 中也可以像平时一般使用条件语句

Promise

const makeRequest = () => {return getJSON().then(data => {if (data.needsAnotherRequest) {return makeAnotherRequest(data).then(moreData => {console.log(moreData)return moreData})} else {console.log(data)return data}})
}

Async

const makeRequest = async () => {const data = await getJSON()if (data.needsAnotherRequest) {const moreData = await makeAnotherRequest(data);console.log(moreData)return moreData} else {console.log(data)return data    }
}
  1. 中间值

在一些场景中,也许需要 promise1 去触发 promise2 再去触发 promise3,这个时候代码应该是这样的

const makeRequest = () => {return promise1().then(value1 => {// do somethingreturn promise2(value1).then(value2 => {// do something          return promise3(value1, value2)})})
}

如过 promise3 不需要 value1,嵌套将会变得简单。如果你有强迫症,则将值1&2使用 promise.all() 分装起来。

const makeRequest = () => {return promise1().then(value1 => {// do somethingreturn Promise.all([value1, promise2(value1)])}).then(([value1, value2]) => {// do something          return promise3(value1, value2)})
}

但是使用 Async 就会变得很简单

const makeRequest = async () => {const value1 = await promise1()const value2 = await promise2(value1)return promise3(value1, value2)
}
  1. 错误栈

如过 Promise 连续调用,对于错误的处理是很麻烦的。你无法知道错误出在哪里。

const makeRequest = () => {return callAPromise().then(() => callAPromise()).then(() => callAPromise()).then(() => callAPromise()).then(() => callAPromise()).then(() => {throw new Error("oops");})
}makeRequest().catch(err => {console.log(err);// output// Error: oops at callAPromise.then.then.then.then.then (index.js:8:13)})

但是对于 Async 就不一样了

const makeRequest = async () => {await callAPromise()await callAPromise()await callAPromise()await callAPromise()await callAPromise()throw new Error("oops");
}makeRequest().catch(err => {console.log(err);// output// Error: oops at makeRequest (index.js:7:9)})

Async/await 和 Promises 区别相关推荐

  1. 【转】6 Reasons Why JavaScript’s Async/Await Blows Promises Away (Tutorial)

    原文:https://hackernoon.com/6-reasons-why-javascripts-async-await-blows-promises-away-tutorial-c7ec105 ...

  2. .then写法和async await 有啥区别?

    最直观的讲一下有啥区别 场景: 三个接口 接口二用到接口一返回的数据 接口三用到接口二和接口一返回的数据 解决方法: promise长啥样: function promise(){return new ...

  3. async/await和Promise区别

    async/await 的优势:可以很好地处理 then 链 对于单一的 Promise 链其实并不能发现 async/await 的优势,当需要处理由多个 Promise 组成的 then 链的时候 ...

  4. es6 --- promise和async/await的区别

    首先需要了解async函数: async是Generator函数的语法糖: // 使用Generator依次读取两个文件 var fs = require('fs'); var readFile = ...

  5. promise 、async/await 的原理及实现

    前言 事件循环机制 由于 javascript 引擎是采用单线程运行机制,执行耗时过大的操作时会造成页面的阻塞,为了解决页面的阻塞问题,js 将任务分为 同步任务.异步任务,随之而来的是异步带来的执行 ...

  6. Async/Await替代Promise的6个理由

    2019独角兽企业重金招聘Python工程师标准>>> 译者按: Node.js的异步编程方式有效提高了应用性能:然而回调地狱却让人望而生畏,Promise让我们告别回调函数,写出更 ...

  7. 写一个符合 Promises/A+ 规范并可配合 ES7 async/await 使用的 Promise

    原文地址 从历史的进程来看,Javascript 异步操作的基本单位已经从 callback 转换到 Promise.除了在特殊场景使用 stream,RxJs 等更加抽象和高级的异步数据获取和操作流 ...

  8. promise 和 async await区别

     什么是Async/Await? async/await是写异步代码的新方式,以前的方法有回调函数和Promise. async/await是基于Promise实现的,它不能用于普通的回调函数. as ...

  9. Callbacks, Promises and Async/Await

    本文转自作者Sandeep Dinesh的文章:Callbacks, Promises and Async/Await 假设你有一个函数可以在一段随机的时间后打印一个字符串: function pri ...

最新文章

  1. 腾讯海量存储与CDN的自动化运维
  2. Docker 第四章 访问容器
  3. 指尖上的艺术——如何运用代码发挥无限创意
  4. java 反射 静态成员_java 利用反射获取内部类静态成员变量的值
  5. Vue 返回记住滚动条位置详解
  6. 高层建筑电气设计说明书
  7. NOIP2018 摸鱼记
  8. pyside6(1):Qt 资源系统和qrc文件使用
  9. iBeacon 介绍
  10. 自学Java day17 jvav网络编程 从jvav到架构师
  11. js本地刷新和局部刷新
  12. 分布式事务实施方案总结
  13. 安全狗陈荣有:打造“即开即用”的云原生安全能力
  14. 利用python打开word文件
  15. tolua 一些可以用的函数(测试过)
  16. pjsip 设置麦克风语音输入量 扬声器播放
  17. 使用ROS-I接口通过MoveIt包安装和操作ABB机器人
  18. android 字体加下划线,如何在Android TextView中将字体样式设置为粗体,斜体和下划线?...
  19. 【工业互联网】周剑:工业互联网平台作用机理和发展路径
  20. 彻底理解thunk函数与co框架

热门文章

  1. 如何做相册_我是如何对2000张照片进行批量套版的
  2. 实现前后台数据交互(上传/回传单个JSON数据和上传/回传JSON数组)
  3. HTML课程表应用,可在PC和Android运行
  4. 猎人能单拿修理机器人图纸_南京创新周麒麟行:他们为铁路配备“体检”机器人...
  5. mysql的槽_Mysql槽点 - MySQL及其它开源数据库 - ITPUB论坛-中国专业的IT技术社区...
  6. linux查看系统的版本信息失败,Linux - 查看系统的版本信息
  7. citrixreceiver云桌面系统_CStack xView桌面云平台与方德操作系统完成兼容性认证
  8. gis插入的文本怎么搞成两行_逻辑图怎么画?图文详解带你绘制逻辑图
  9. 查看oracle的版本、所在表空间、字符集及查询一个表的所有字段名和数据类型
  10. 智能一代云平台(九):EclipseLink返回Object转为实体的分析