美文网首页
深入浅出ES6教程『async函数』

深入浅出ES6教程『async函数』

作者: 叔叔的万卷书 | 来源:发表于2019-10-10 11:38 被阅读0次

【文章转载自 苏日俪格】

大家好,本人名叫苏日俪格,大家叫我(格格)就好,在上一章节中我们学到了Symbol & generator的用法,下面我们一起来继续学习async函数:

async [ə'zɪŋk]:这个单词看起来很怪异,它的原型是asynchrony,意为异步,一般单词按理说都能把音准读个大概,这个就...

与其同时呢,也有的人看了这个词想到了放在script标签里的异步脚本,但是此async非彼async,这个async是ES2017出来的,也是用来处理异步的,和ES6中的promise类似,nodeJs里面有一个典型的异步操作,下面用三种异步处理方式来读取文件readFile():

1、promise来读取文件

然后用node来运行该文件,打开命令行(win+r):

因为读取多个文件一般都会作为一个异步来处理,这样就不会阻塞程序的运行,把fs封装成一个Promise对象,然后在下面返回数据输出,例子中的TXT文件可以写自己的数据

2、generator函数读取文件

依然用node运行即可,这种方式代码量又高了不少,和Promise方式特别像,只不过是把读取文件的信息放在了外面,在下面依次手动调用,特别麻烦,下面我们来介绍第三种方式:

3、async函数读取文件

这个函数和generator函数有些类似,从例子中可以看得出来,async函数在function前面有个async作为标识,意思就是异步函数,里面有个await搭配使用,每到await的地方就是程序需要等待执行后面的程序,语义化很强,下面总结一下async函数的特点

语义化强

里面的await只能在async函数中使用

await后面的语句可以是promise对象、数字、字符串等

async函数返回的是一个Promsie对象

await语句后的Promise对象变成reject状态时,那么整个async函数会中断,后面的程序不会继续执行

基于上面的async的特点,我们会用到异常捕获机制,学过java的都知道,java中有异常捕获try...catch...

小白:这个东西是干什么的?

格格:下面让我们来看一下它的概念

try/catch/finally 语句用于处理代码中可能出现的错误信息。

错误可能是语法错误,通常是程序员造成的编码错误或错别字。也 可能是拼写错误或语言中缺少的功能(可能由于浏览器差异)。

try语句允许我们定义在执行时进行错误测试的代码块。

catch语句允许我们定义当try代码块发生错误时,所执行的代码块。

finally语句在 try 和 catch 之后无论有无异常都会执行。

注意:catch 和 finally 语句都是可选的,但你在使用 try 语句时必须至少使用一个。

提示:当错误发生时, JavaScript 会停止执行,并生成一个错误信息。使用throw语句 来创建自定义消息(抛出异常)。如果你将throwtrycatch一起使用,就可以控制程序输出的错误信息。

知道了这个东西是干什么的,那么我们在async中怎么用呢?

大家看完了这个async是不是感觉还挺有用的啊,以后工作中async就会替代generator,原理是Promise,所以说特别好用。

关于async函数我们都已经了然于心,预知Set & Map数据结构如何,请听下回分解 (^∀^)/~~~

相关文章

  • 深入浅出ES6教程『async函数』

    大家好,本人名叫苏日俪格,大家叫我 (格格) 就好,在上一章节中我们学到了Symbol & generator的用...

  • 深入浅出ES6教程『async函数』

    【文章转载自 苏日俪格】 大家好,本人名叫苏日俪格,大家叫我(格格)就好,在上一章节中我们学到了Symbol & ...

  • 深入浅出ES6教程 async函数

    async是ES2017出来的,有时候ajax请求需要做同步处理,就是ajax如何同步请求,那就用到它了;和ES6...

  • async await

    文档地址async[http://caibaojian.com/es6/async.html] async函数的语...

  • async/await 整理总结

    参考:红宝书 es6入门 async async 函数的实现原理,就是将 Generator 函数和自动执行器,包...

  • 异步的那些事儿,promise

    promise 是es6 的标准函数,主要是解决执行函数当中的回调问题,相对于async,async只是一套解决回...

  • JS新特性

    ES ES5 ES6 箭头函数 Promise Symbol属性 Iterator Generator async...

  • ES6 知识点整理

    ES6 包括 变量、函数、数组、json、字符串、面向对象、promise、generator、async/awa...

  • async awit

    阮一峰ES6 async... await 教程 读取文件 fs.readFile1. promise2. ge...

  • 一次性搞懂 Promise、async await 与 Gene

    学习 ES6 的时候,经常听到 Promise、async await 与 Generator 用来处理异步函数,...

网友评论

      本文标题:深入浅出ES6教程『async函数』

      本文链接:https://www.haomeiwen.com/subject/hkmopctx.html