0

0

了解异步操作并在 JavaScript 中使用 async/await

王林

王林

发布时间:2024-09-10 19:11:47

|

512人浏览过

|

来源于dev.to

转载

正如您所知,javascript 是一种单线程语言,它一次只能执行一个操作。然而,web 开发中的许多操作(包括从服务器提取数据或读取磁盘中的文件)可能需要一些时间才能完成。如果它确实同步执行这些操作,这意味着 javascript 必须等到操作完成才能转到下一行代码,那么它将降低应用程序的响应速度。为了更高效地完成此类任务,javascript 采用了异步编程技术。

什么是异步操作?

异步操作是在当前时间启动但允许在其他时间完成而程序继续执行其他代码行的操作。在 JavaScript 中,异步行为的处理是通过使用回调、promise 以及后来的 async/await 语法来完成的。这种方法使 JavaScript 在后台执行任务,从而提高 Web 应用程序的整体性能。
例如,考虑在 Web 应用程序中必须从数据库检索有关用户的信息的情况。此过程可能需要几秒钟,具体取决于网络速度或服务器的高流量。 JavaScript 可以继续执行其余代码,而不是在等待接收数据时停止应用程序。这种非阻塞行为是异步编程背后的基本思想。

引入异步/等待

async/await 语法是 ES2017 (ES8) 的一部分,可以说是处理异步代码的最优雅且易于理解的方法。它基于 Promises,并提供了一种将异步代码看起来像同步代码的方法,以便于理解和维护。
异步函数是以 Promise 作为其返回类型的函数。 async 关键字附加到函数时告诉程序该函数将始终返回 Promise,无论是否实际返回 Promise。 Await 用于异步函数内部,以允许函数等待 Promise 完成或拒绝。

async/await 如何工作?

现在让我用一个例子来说明如何使用 async/await。考虑以下代码片段,该代码片段检索用户的购物车并显示它:

了解异步操作并在 JavaScript 中使用 async/await

在这个例子中,getCart函数被声明为async,因此,它可以使用await关键字来处理其中的异步操作。

Joker AIx
Joker AIx

一站式AI创意生产平台,覆盖图像、视频、音频、文案全品类创作

下载
  1. const cart = wait req.user.getCart();:这会调用用户对象上的 getCart 方法,检索用户当前的购物车实例。 wait 关键字确保 JavaScript 等待 getCart() 返回的 Promise 完成。然后将解析后的值(用户的购物车)分配给 cart 变量。
  2. const products = wait cart.getProducts();:同样,此行会暂停代码的执行,直到 getProducts 方法完成,这会将产品添加到用户的购物车中。 wait 关键字告诉 CLR 在产品数据准备好之前不应执行以下代码行。
  3. 渲染响应:完成两个异步操作后,执行变量 res.render() 以在产品旁边渲染购物车页面。
  4. try...catch 的错误处理:try...Finally,catch 块用于处理由于异步操作可能出现的任何异常。如果任何一个await语句出现错误,catch块就会处理该错误并将其记录到控制台。

使用 async/await 的好处

与传统的基于 Promise 的代码相比,async/await 语法具有多种优势:与传统的基于 Promise 的代码相比,async/await 语法具有多种优势:
• 提高可读性:很容易理解和理解,因为尽管它能够处理异步操作,但代码看起来像普通的同步代码。
• 错误处理:使用 try...Async/await 使错误处理像使用sync/async 捕获错误一样简单和统一。
• 简化复杂操作:对于有多个异步操作的代码应该使用async/await,因为这样代码会更容易编写、测试和调试。

结论

异步编程在 JavaScript 中尤其重要,可以在不停止主线程的情况下执行计算密集型操作。 async/await 语法提供了一些更复杂的方法来处理这些操作,并且生成的代码更易读、更干净且更易于调试。 Async/await 帮助开发人员编写异步代码,这使得他们的应用程序更可预测、更快。

立即学习Java免费学习笔记(深入)”;

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

562

2023.09.20

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

765

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

765

2023.08.10

promise的用法
promise的用法

“promise” 是一种用于处理异步操作的编程概念,它可以用来表示一个异步操作的最终结果。Promise 对象有三种状态:pending(进行中)、fulfilled(已成功)和 rejected(已失败)。Promise的用法主要包括构造函数、实例方法(then、catch、finally)和状态转换。

337

2023.10.12

html文本框类型介绍
html文本框类型介绍

html文本框类型有单行文本框、密码文本框、数字文本框、日期文本框、时间文本框、文件上传文本框、多行文本框等等。详细介绍:1、单行文本框是最常见的文本框类型,用于接受单行文本输入,用户可以在文本框中输入任意文本,例如用户名、密码、电子邮件地址等;2、密码文本框用于接受密码输入,用户在输入密码时,文本框中的内容会被隐藏,以保护用户的隐私;3、数字文本框等等。

428

2023.10.12

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

386

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2111

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

357

2023.08.31

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号