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

async 与 await

目录

  • 一、async函数
  • 二、await表达式
  • 三、async与await结合


一、async函数

  1. 函数的返回值为promise对象
  2. promise对象的结果由async函数执行的返回值决定
async function main(){//1.如果返回的是一个非promise类型的数据,那么返回的就是成功的状态// return 521//2.如果然会的是一个promise对象return new Promise((resolve,reject)=>{// 2.1返回的状态由promise对象返回值决定resolve('ok')// reject('error')// 2.2 如果抛出异常// throw new Error('error') 结果就是抛出的异常 状态为失败})
}
let result = main();
console.log(result);

和then的返回一模一样

二、await表达式

  1. await右侧的表达式一般为promise对象,但也可以是其他的值。
  2. 如果表达式是promise对象,await返回的是promise成功的值
  3. 如果表达式是其他值,直接将此值作为await的返回值

注意:

  1. await必须卸载async函数中,但是async函数中可以没有await
  2. 如果await的promise失败了,就会抛出异常,需要通过try…catch捕获处理
async function main(){let p = new Promise((resolve,reject)=>{resolve('ok')})//1.右侧为promise的情况let res =await pconsole.log(res)//ok//2.右侧为其他类型的数据let res2 = await 123console.log(res2)//123
}

通过try/catch捕获错误

    async function main() {let p = new Promise((resolve, reject) => {reject('error')})try {let result = await p} catch (e) {console.log(e)}}main()

在这里插入图片描述

三、async与await结合

  1. 使用回调函数的方式实现
    在这里插入图片描述
  2. async 与 await
    在这里插入图片描述
    在这里插入图片描述
http://www.lryc.cn/news/45088.html

相关文章:

  • MYSQL语句
  • C语言函数:内存函数memcpy()以及实现
  • ArcGIS基础:栅格分区转矢量再裁剪面图层【重分类】【栅格转面】
  • vue尚品汇商城项目-day02【11.对axios二次封装+12.接口统一管理】
  • 并发编程-2
  • 万字解析Linux内核调试之动态追踪
  • Spring Boot 各层作用与联系
  • 苦中作乐---竞赛刷题(15分-20分题库)
  • 超详细,多图,PVE安装以及简单设置教程(个人记录)
  • 茴子的写法:关于JAVA中的函数传递语法糖:lambda
  • 动态规划刷题记录(2)
  • 2023年广东省网络安全竞赛——Web 渗透测试解析(超级详细)
  • MI-SegNet阅读笔记
  • 十、MyBatis分页插件
  • EasyCVR平台国标GB28181协议设备接入时,可支持过滤通道类型
  • 玩转git的第1章节:git的理论以及操作规则
  • 【新2023Q2模拟题JAVA】华为OD机试 - 二叉树层次遍历
  • 轻松拿结果-第三部分 同欲 -第六章 有凝聚力才有战斗力
  • chatGPT 会给程序员带来失业潮吗?
  • Vue项目proxyTable跨域配置
  • ubuntu16.04搭建gitlab
  • SSMP综合案例
  • 让你的作品更出色——词云Word Cloud的制作方法(基于python,WordCloud,stylecloud)
  • axios请求拦截器
  • 四个常见的Linux技术面问题
  • 有什么适合程序员查资料的网站
  • (七)手把手带你搭建精美简洁的个人时间管理网站—实现登录与注册的前端代码【源码】
  • Day933.如何将设计最终落地到代码 -系统重构实战
  • 209. 长度最小的子数组
  • 【数据结构与算法】查找(Search)【详解】