JavaScript中的async/await的用法和理解

举报
青年码农 发表于 2022/08/24 22:28:10 2022/08/24
【摘要】 昨天更新的是“JavaScript中的Promise使用详解”,其实也就是说了下基本用法和自己对Promise的理解,可能有错误之处,也欢迎指出。今天就说一说“JavaScript中的async/await的用法和理解” 编程语言中任意一个关键字都是有意义的,我们先从字面意思来理解。 1.async  asyn...

昨天更新的是“JavaScript中的Promise使用详解”,其实也就是说了下基本用法和自己对Promise的理解,可能有错误之处,也欢迎指出。今天就说一说“JavaScript中的async/await的用法和理解”

编程语言中任意一个关键字都是有意义的,我们先从字面意思来理解。

1.async 

ed2b1330a3eba089c88d3acf355396e1.png

async 是“异步”的简写,带async关键字的函数,是声明异步函数,返回值是promise对象,如果async关键字函数返回的不是promise,会自动用Promise.resolve()包装。


   
  1. async function test() {
  2.     return 'hello word'
  3. }
  4. test();

运行上面代码返回结果如下

c4cc6481a4702764897937b8d3a76c98.png

2.await 

c65e8f6962fa2c760b1eea4880699113.png

await 可以认为是 async wait 的简写。所以应该很好理解 async 用于申明一个 function 是异步的,而 await 用于等待一个异步方法执行完成。

如果它等到的不是一个 Promise 对象,那 await 表达式的运算结果就是它等到的东西。

如果它等到的是一个 Promise 对象,await 就忙起来了,它会阻塞后面的代码,等着 Promise 对象 resolve,然后得到 resolve 的值,作为 await 表达式的运算结果。

我们看下面段代码


   
  1. function test() {
  2.     return new Promise(resolve => {
  3.         setTimeout(() => resolve("hello word"), 2000);
  4.     });
  5. }
  6. const result = test();
  7. console.log(result.then((val)=>{console.log(val)}));
  8. console.log('结束')

我们以编辑器编辑器代码执行顺序来理下,

1.首先我们定义一个方法,这个方法返回Promise 对象,.then()函数两秒钟后返回调用成功。

2.接下来实例化test()函数。

3.调用result对象的then()函数,接收返回值,注意,这里是异步的

4.打印日志结束

我们运行代码,看结果

e479c8a976dd48a496bb919b36a89cb0.png

看到先打印“结束”,然后才打印的“hello word”,这就是异步,我们改造下代码


   
  1. function test() {
  2.     return new Promise(resolve => {
  3.         setTimeout(() => resolve("hello word"), 2000);
  4.     });
  5. }
  6. const result = await test();
  7. console.log(result);
  8. console.log('结束')

用await关键字接test()函数,看这次返回结果

82d0694f6bea243ba7d6026a8e63dc79.png

我们发现先打印“hello word”,然后才打印“结束”,由于test()造成的阻塞,console.log('结束')会等到两秒后执行。

再来说下优缺点

优点:相对于promise,async/await处理 then 的调用链,代码要清晰很多,几乎和同步代码一样。

缺点:滥用 await 可能会导致性能问题,因为 await 会阻塞代码。

文章来源: blog.csdn.net,作者:NMGWAP,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/NMGWAP/article/details/125066870

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。