0

0

javascript如何使用async_await_它如何简化异步代码【教程】

狼影

狼影

发布时间:2026-01-28 16:17:10

|

744人浏览过

|

来源于php中文网

原创

async/await 是 Promise 的语法封装而非语法糖,async 函数自动返回 Promise,await 必须在 async 函数内使用,错误需用 try/catch 捕获,多请求应优先用 Promise.all 并发。

javascript如何使用async_await_它如何简化异步代码【教程】

async/await 不是语法糖的替代品,而是 Promise 的语法封装;它不能消除异步本质,但能显著降低回调嵌套和错误处理的复杂度。

async 函数必须显式返回 Promise

声明为 async function 的函数,无论内部是否用 await,其返回值都会被自动包装成 Promise。直接 return 一个普通值(如 return 42),等价于 return Promise.resolve(42);如果 throw 错误,则等价于 return Promise.reject(error)

常见错误:在 async 函数里忘记 await 调用另一个 async 函数,导致返回的是 pending Promise 而非实际值。

  • ✅ 正确写法:const data = await fetchUser();
  • ❌ 错误写法:const data = fetchUser(); // data 是 Promise,不是用户对象
  • ⚠️ 注意:顶层 await 只在模块作用域(.mjstype="module" script)中合法,普通脚本中会报 SyntaxError: await is only valid in async function

await 只能在 async 函数内部使用

await 不是全局操作符,它依赖 async 函数提供的执行上下文来暂停和恢复执行。试图在普通函数、事件回调、或 for 循环顶层直接写 await 都会触发语法错误。

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

典型场景:想在点击事件里等待 API 响应,但忘了把事件处理函数声明为 async。

Android高手进阶教程之 Android Widget开发案例
Android高手进阶教程之 Android Widget开发案例

Android高手进阶教程(八)之----Android Widget开发案例(世界杯倒计时!),主要向大家讲解使用Android Widget如何编写出一款世界杯风格的倒计时程序,教程说出了制作步骤和代码。

下载
  • ✅ 正确:button.addEventListener('click', async () => { const res = await apiCall(); render(res); });
  • ❌ 报错:button.addEventListener('click', () => { const res = await apiCall(); }); // Uncaught SyntaxError
  • ? 补充:箭头函数也需加 async,不能只靠外层函数“传染”

错误处理要用 try/catch,而不是 .catch()

await 会让 Promise rejection 变成同步抛出的异常,因此必须用 try/catch 捕获——用 .catch() 会失效,因为 await 已经把链式调用“打断”了。

容易踩的坑:混用 await.catch(),以为能兜住错误,结果未捕获的 rejection 触发 Uncaught (in promise)

  • ✅ 推荐:
    try {
      const data = await fetch('/api').then(r => r.json());
    } catch (err) {
      console.error('请求失败', err);
    }
  • ❌ 无效:await fetch('/api').catch(handleError); // catch 不会阻止 rejection 向上冒泡
  • ⚠️ 注意:await Promise.reject('boom') 会立即进入 catch 分支,行为完全同步可预测

多个异步操作的并发控制要小心

await 默认是串行的:前一个没结束,后一个不开始。想并行发起多个请求(比如同时拉用户信息和订单列表),得用 Promise.all() 包装,而不是连续 await。

性能影响明显:串行 await 5 个 200ms 请求耗时约 1s;Promise.all([a(), b(), c()]) 理论上只要最慢那个的时间(200ms)。

  • ✅ 并行:const [user, orders] = await Promise.all([fetchUser(), fetchOrders()]);
  • ❌ 串行(低效):const user = await fetchUser(); const orders = await fetchOrders();
  • ? 提示:Promise.allSettled() 更适合容错场景,避免单个失败导致全部中断

真正难的从来不是写对 async/await,而是判断哪些操作该串行、哪些该并行、哪些该降级或超时控制——这些逻辑不会因语法变简洁而自动消失。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

208

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

296

2023.10.25

c语言const用法
c语言const用法

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

530

2023.09.20

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

482

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

163

2023.10.07

promise的用法
promise的用法

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

306

2023.10.12

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

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

405

2023.10.12

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

109

2026.01.26

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.2万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

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

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