当前位置: 首页 > news >正文

js中async+await+promise的用法及常见问题总结

文章目录

    • 概况
    • async
    • await
    • Promise
    • 总结常见问题

概况

  • 在ts/js中,async 和 await 是用于简化异步操作的关键字,一般与Promise联用(不理解Promise可以看一下这篇《JS中Promise用法(简要说明)》)。
  • 它们的核心作用是让异步代码的写法更接近同步代码的逻辑,同时保持非阻塞特性。

async

  • 标记函数为异步函数,自动或者主动返回一个 Promise
当你没有显式定义Promise时就会立即自动返回完成的Promise
在这里插入图片描述
当你显式定义Promise时会返回一个根据具体情况变化状态的Promise
在这里插入图片描述
返回值自动包装为Promise<泛型>的例子
在这里插入图片描述

await

  • 暂停函数执行(即停在await修饰的函数那),直到修饰的调用函数返回的Promise完成
await具有暂停直到修饰函数的Promise变为完成状态才继续执行后续代码的能力
在这里插入图片描述

Promise

  • async和Promise是关联的,这里列出来可能的返回类型。
函数返回值Promise类型示例
无return语句Promise< void > (自动包装)async function f(){}
返回类型T(如T为number)Promise< number > (自动包装)async function f(){ return 1; }
返回Promise< T >Promise< T >(不存在自动包装)async function f(){ return Promise.resolve(t); //t instanceof T}
  • async修饰的函数,始终返回Promise,那么返回的Promise何时算完成?
状态触发方式1触发方式2
解决(Resolve)A、【return】函数没报错,正常执行完(返回)C、调用executor提供的【resolve() 】
拒绝(Reject)B、【throw】函数抛出错误C、调用executor提供的【reject()】
// A、函数没报错,正常执行完(返回)
async function resolveExample() {
  return "success"; // 等价于 Promise.resolve("success")
  // 也可以不需要return
}
// B、函数抛出错误
async function rejectExample() {
  throw new Error("failed"); // 等价于 Promise.reject(error)
}
// C、调用executor提供的两个函数类型的参数resolve, reject
async function timeout(delay: number) {
  return new Promise((resolve, reject) => { //executor提供的两个函数类型的参数resolve, reject
    if (delay < 0) {
      reject("Invalid delay");
    } else {
      setTimeout(() => resolve("Timeout done"), delay);
    }
  });
}

总结常见问题

  • Q:await可以处理什么值?
  • A:用来处理Promise的,但是可以是任何值,因为就算不是Promise,也会自动包装为Promise
  • Q:对于一个函数,await可以单独出现吗?
  • A:要想函数体内部使用await,必须用async修饰函数(否则报错)。
  • Q:async修饰的函数,返回值是什么?
  • A:任何标记为 async 的函数,无论内部是否包含 await(其实返回值和await没有关系),始终返回 Promise。
  • Q:async修饰的函数,没有显式返回Promise时会发生什么?
  • A:自动将函数返回值包装为一个立即解决的 Promise。
  • Q:通过 await 调用的函数,必须返回 Promise 吗?
  • A:不是必须,但强烈建议。(被调函数如果显式返回Promise则解决了再执行后续,没有返回则自动包装一个立即解决的Promise)
  • Q:如果一个async函数A,函数A的内部仅仅只有一行代码,通过await 调用了一个函数B,问通过变量C接收函数A返回的Promise对象,Promise对象是怎么样的?
  • A:如果函数B调用了resolve(),变量C是一个undefined的结果(因为没有任何return,所以是自动包装了个undefined); 如果函数B调用了reject(),此时变量C是一个和函数B一样的Promise状态(可以理解为继承了内部的没有捕获的异常状态); 如果给函数B调用的地方增加了try catch捕获异常,哪怕是函数B调用了reject(),变量C得到的是一个undefined的Promise结果(因为没有任何return,所以是自动包装了个undefined),这里可以得出,只要async函数A正常执行完毕,就算没有return,都会返回一个undefined结果的Promise。

相关文章:

  • Linux多线程详解
  • Docker镜像相关命令(Day2)
  • 【大模型】数字人 EchoMimicV2 的环境配置和使用
  • 基于Logisim的汉字显示模拟实验
  • 详细比较StringRedisTemplate和RedisTemplate的区别及使用方法,及解决融合使用方法
  • OLLVM 增加 CC++ 字符串加密功能
  • std::unordered_map和 std::map的区别
  • 代码随想录算法训练营第十一天| 150. 逆波兰表达式求值、239. 滑动窗口最大值、347.前 K 个高频元素
  • leetcode 20.有效括号
  • 网络运维学习笔记(DeepSeek优化版) 023 HCIP-Datacom OSPF邻居建立过程、四种网络类型、OSPF高级配置、LSA类型与管理
  • 企业级部署zabbix分布式监控系统
  • C++数据结构(搜索二叉树)
  • 【SOC 芯片设计 DFT 学习专栏 -- IDDQ 测试 与 Burn-In 测试】
  • 使用CSS3实现炫酷的3D视差滚动效果
  • 综合小实验之电视机
  • <数据集>手势识别数据集<目标检测>
  • fpga pcie
  • javaSE.多维数组
  • 后大模型时代智能体将成为“新宠”
  • 使用go实现导入Rxcel数据到数据库并渲染到页面上
  • win2008系统做网站/seo点石论坛
  • 台州城乡建设局网站/seo网站关键词排名优化公司
  • 申请一个网站空间/可以免费发广告的网站有哪些
  • asp.net获取网站bin目录/培训学校加盟费用
  • 网站优化关键词公司/web成品网站源码免费
  • 北京城乡住房建设厅网站/阿里指数