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

js代码中关于async await的滥用 async await的滥用

概念:

返回值: async返回一个promise---这个返回值是默认自发行为

async function name1(params) {console.log(params)
}
let result = name1('lion')
console.log(result) // Promise { undefined }
result.then(res => console.log(res)) // undefined

正题

很多时候不知道该不该加async,导致async,await满天飞

demo:

function timeout(ms) {return new Promise((resolve, reject) => {setTimeout(resolve, ms, 'done');});
}
async function timeout2() {let res = await timeout(3000)console.log('done: 3000')
}
async function timeout3() {let res = await timeout(2000)console.log('done: 2000')
}

现在有个函数想要执行timeout2、timeout3,期待打印顺序肯定是: 'done: 3000' ;'done: 2000'

1、方式:timeout2、timeout3已经是async ,awiat 那么handleTimeout这么写行不行?

function handleTimeout() {timeout2()timeout3()
}
handleTimeout()
// done: 2000
// done: 3000

2、方式:name2 name3已经是async ,awiat 那么handleTimeout这么写行不行?

async function handleTimeout() {timeout2()timeout3()
}
handleTimeout()
// done: 2000
// done: 3000

3、正确的

async function handleTimeout() {await timeout2()await timeout3()
}
handleTimeout()
// done: 3000
// done: 2000

思想: 只看单个方法,别看那么宏观。

解析: 在async函数中,可能会有N个异步处理(promise),我们都用await进行控制时序,当前面的一系列的异步执行完毕后,最终return是一个promise(无论你是否真的在code中return一个promise)

http://www.lryc.cn/news/345995.html

相关文章:

  • 基础算法,贪心算法,贪心策略,OJ练习
  • 一文讲透亚马逊云三层架构
  • 只需3步,使用Stable Diffusion无限生成AI数字人视频(附安装包)
  • RustGUI学习(iced)之小部件(七):如何使用图像image部件来显示图片?
  • Substrate 入门课第 14 期圆满结束,岗位内推直达知名 Web3 项目!
  • android进阶-AIDL
  • 贪心算法-活动选择问题背包问题
  • Web3工具集合 - 00
  • 分布式与集群的区别
  • 学习心得:如何开始学习一款MCU
  • 顺序表的实现(迈入数据结构的大门)(1)
  • RERCS系统-WDA+BOPF框架实战例子 PART 1-新建List UIBB(列表组件)并分配Feeder Class和Node Element
  • 如何从 iPhone 恢复已删除或丢失的联系人?
  • RISCV 外部GCC 工具链安装@FreeBSD15
  • 全栈开发之路——前端篇(9)插槽、常用api和全局api
  • 减瘦误区、雷点、陷阱和挑战怎么应对
  • Leetcode—946. 验证栈序列【中等】
  • Selenium定位方法及代码
  • GitHub搭建免费博客
  • 开源代码分享(28)-含分布式光伏的配电网集群划分和集群电压协调控制
  • idea-自我快捷键-2
  • 深入学习指针3
  • 礼赞劳动节,致敬劳动者。节日随想:疾笔耕耘也是一种劳动方式。
  • 学习Java的日子 Day45 HTML常用的标签
  • 兔子与狮子
  • GNU/Linux - 系统启动流程及rcS脚本介绍
  • 对象,字符串的解构赋值
  • Django 静态文件管理与部署指南
  • ORACLE ODAX9-2的一个误告警Affects: /SYS/MB的分析处理
  • Spring AOP浅谈