ES6之async函数

     async函数,类似generator函数都是为了方便于异步操作,而且表现形式也很类似只是将*变成 async,yield变成了await。但是async函数执行不像generator函数需要next、throw、return等手动控制执行,它是跟正常函数一样的执行;async函数的表现比generator函数表现的更明确,更方便于异步操作(async包含异步操作,await后的表达式需要等待结果);async函数中的适用性更广泛,await后面跟的表达式比yield更广泛(虽然await之后的东西都会转化为Promise对象);async函数返回的是一个Promise对象generator函数返回的是一个Iterator对象。

      async函数返回的是一个Promise对象,所以一切ES6上的Promise的操作都可以适用于这个,而且它的内部机制是遇到await就先返回执行,执行结束后就接着执行函数体内后面的函数,类似jquery中ajax的async=false,具体可以写下代码理解下,async函数内部抛出错误会直接将Promise的状态变成rejected,抛出的错误会被catch捕捉到回调函数中。async函数除了return或者throw之外只有所有await函数执行完,状态才会发生改变,才会去执行then方法,注意:只要await后面的Promise对象变成reject,整个async函数都会中止执行除非将它放到try..catch中或者Promise自带的catch;await只能存在在async函数中,否则会报错;async函数中两个相互独立的异步操作建议一次执行。

      async函数的执行原理:将Generator函数和自动执行器包装成一个函数。异步遍历器为异步操作提供原生的遍历器接口,可以通过调用next方法返回一个Promise对象,resolve之后的参数具有value和done的属性。for..of..遍历同步遍历器,for ..await..of遍历异步遍历器。

       剩下的就是一些对异步遍历器的表现形式,不想写了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 异步编程对JavaScript语言太重要。Javascript语言的执行环境是“单线程”的,如果没有异步编程,根本...
    呼呼哥阅读 7,333评论 5 22
  • 文章内容转自阮一峰老师博客.语法学习 1.返回 Promise 对象 async函数返回一个Promise 对象。...
    四月天__阅读 416评论 0 0
  • 简单介绍下这几个的关系为方便起见 用以下代码为例简单介绍下这几个东西的关系, async 在函数声明前使用asyn...
    _我和你一样阅读 21,252评论 1 24
  • 弄懂js异步 讲异步之前,我们必须掌握一个基础知识-event-loop。 我们知道JavaScript的一大特点...
    DCbryant阅读 2,747评论 0 5
  • 在此处先列下本篇文章的主要内容 简介 next方法的参数 for...of循环 Generator.prototy...
    醉生夢死阅读 1,463评论 3 8