Chapter 10 async函数 await关键字

2024-09-03 10:20

本文主要是介绍Chapter 10 async函数 await关键字,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

欢迎大家订阅【Vue2+Vue3】入门到实践 专栏,开启你的 Vue 学习之旅!

文章目录

  • 前言
  • 一、async 函数
  • 二、await 关键字


前言

在现代 JavaScript 开发中,异步编程是一个重要的概念。随着 ES2017 的引入,async 函数和 await 关键字为处理异步操作提供了更简洁和可读的方式。本章详细讲解了这两个关键字的特性及其用法。


一、async 函数

async 函数是使用 async 关键字声明的异步函数。async 函数是 AsyncFunction 构造函数的实例,并且其中允许使用 await 关键字。
async 函数会返回一个 Promise 对象。即使函数内部没有显式返回 Promise,JavaScript 也会将其返回值包装成一个 Promise

【示例】

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><script>async function example() {  return "Hello, World!";  }  example().then(result => console.log(result)); </script>
</body>
</html>

运行结果:
控制台打印输出“Hello, World!”
在这里插入图片描述
【分析】
本例代码定义了一个异步函数example,该函数返回一个解析为 “Hello, World!” 的 Promise。通过调用这个函数并使用 then 方法将 “Hello, World!” 输出到控制台。

async function example() {  return "Hello, World!";  
} 
  • async 关键字:在函数前加上 async 关键字,声明这个函数是一个异步函数,会返回一个 Promise 对象。
  • 函数体:JavaScript 会自动将字符串 "Hello, World!"包装成一个 Promise,该函数实际上返回的是一个解析为 “Hello, World!” 的 Promise
example().then(result => console.log(result));
  • 调用函数:当调用 example() 时,它会立即返回一个 Promise
  • .then() 方法then 方法用于处理 Promise 的结果。它接受一个回调函数作为参数,这个回调函数会在 Promise 被解析时执行。
  • result 参数:当 Promise 被解析时,result 将接收到 Promise 的解析值。在本例子中,result"Hello, World!"

执行流程如下:
①调用 example(),返回一个 Promise,状态是“待定”(pending);
return "Hello, World!";,返回值(“Hello, World!”)被包装成一个 Promise,并且状态变为“已解决”(fulfilled);
.then() 中的的回调函数被调用,result 参数接收到 “Hello, World!”,并在控制台输出。

二、await 关键字

await 关键字只能在 async 函数内部使用。它用于等待一个 Promise 被解析或拒绝。
asyncawait 关键字让我们可以用一种更简洁的方式写出基于 promise 的异步行为,而无需刻意地链式调用 promise 。

【示例】

async function fetchData() {const response = await fetch('https://api.example.com/data');const data = await response.json();return data;
}
fetchData().then(data => console.log(data));

async function fetchData() { ... }

  • async 关键字:该关键字用于定义一个异步函数。异步函数允许你在函数内部使用 await 关键字来等待异步操作完成。
  • fetchData:函数名称,用于从指定的 API 获取数据。

const response = await fetch('https://api.example.com/data');

  • fetch 函数:一个内置的 JavaScript 函数,用于发起网络请求。它返回一个 Promise,表示请求的结果。
  • await 关键字:用于等待 fetch 函数返回的 Promise 被解析,即代码会在这一行暂停,直到请求完成并返回响应。
  • response:请求的响应对象,包含了服务器返回的数据和状态信息。

const data = await response.json();

  • response.json():用于将响应体解析为 JSON 格式的数据,返回一个 Promise,表示解析的结果。
  • await:代码会在这一行暂停,直到 response.json() 返回的 Promise 被解析。
  • data:解析后的数据,通常是一个 JavaScript 对象或数组,包含了从 API 获取的信息。

return data;:将解析后的数据返回给调用 fetchData 函数的地方。
.then(data => console.log(data)):一个链式调用,用于处理 fetchData 返回的 Promise

  • then 方法接受一个回调函数,当 Promise 被解析时,这个回调函数会被调用。
  • data 参数将接收到 fetchData 返回的数据。
  • console.log(data):将获取到的数据输出到控制台。

执行流程如下:

  1. 调用 fetchData() 函数;
  2. fetchData 函数内部,发起网络请求到 https://api.example.com/data
  3. 等待请求完成,并获取响应;
  4. 将响应解析为 JSON 数据;
  5. 返回解析后的数据;
  6. 在调用 fetchData() 的地方,使用 .then() 方法处理返回的数据,并将其输出到控制台。

这篇关于Chapter 10 async函数 await关键字的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1132704

相关文章

C#中lock关键字的使用小结

《C#中lock关键字的使用小结》在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时,其他线程无法访问同一实例的该代码块,下面就来介绍一下lock关键字的使用... 目录使用方式工作原理注意事项示例代码为什么不能lock值类型在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客