码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • async/await实现Promise.acll()


    🐱个人主页:不叫猫先生
    🙋‍♂️作者简介:专注于前端领域各种技术,热衷分享,期待你的关注。
    💫系列专栏:vue3从入门到精通
    📝个人签名:不破不立

    目录

      • 一、Promise.all()简介
      • 二、async/await实现Promise.all()
        • 1、方式一
        • 2、方式二
      • 三、async/await与Promise.all()结合使用

    一、Promise.all()简介

    Promise.all() 方法接收一个 promise 的 iterable 类型(注:Array,Map,Set 都属于 ES6 的 iterable 类型)的输入,并且只返回一个Promise实例,并且输入的所有 promise 的 resolve 回调的结果是一个数组。

    • Promise的 resolve 回调执行是在所有输入的 promise 的 resolve 回调都结束,或者输入的 iterable 里没有 promise 了的时候
    • Promise的 reject 回调执行是只要任何一个输入的 promise 的 reject 回调执行或者输入不合法的 promise 就会立即抛出错误,并且只要有 reject 就会立即抛出的错误信息。

    二、async/await实现Promise.all()

    先定义三个Promise实例对象,并放置于一个数组中

            let a = new Promise((res, rej) => {
    			res(1)
    		}).catch(err => console.log(err))
    		let b = new Promise((res, rej) => {
    			setTimeout(() => {
    				rej(2)
    			}, 2000)
    		}).catch(err => console.log(err))
    		let c = new Promise((res, rej) => {
    			res(3)
    		}).catch(err => console.log(err))
           const arr = [a, b, c]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    1、方式一

    -使用async/await,循环遍历Promise实例对象的数组,并把每个Promise对象的结果放置于一个空数组中。

    		async function bb() {
    			let arr1 = [];
    			try {
    				for (let i = 0; i < arr.length; i++) {
    					let h = await arr[i]
    					arr1.push(h)
    				}
    			} catch (err) {
    			}
    			return arr1
    		}
    		
    		bb().then(res => {
    			console.log(res); //[1, undefined, 3]
    		});
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    undefined是因为await只处理成功时resolve(),不处理失败异常,故返回undefined

    2、方式二

    该方面类似实现手写Promise.acll(),等await拿到Promise结果然后count加1,知道count的数值等于数值的长度在resolve()

          const all = (arr) => {
      			return new Promise((resolve, reject) => {
    				let length = arr && arr.length
    				let count = 0
    				let result = []
    				if (!arr || arr.length === 0) {
    					resolve(result)
    				}
    				arr.forEach(async (item, index) => {
    					try {
    						const res = await item
    						result[index] = res
    						count++
    						if (count === length ) {
    							resolve(result)
    						}
    					} catch (err) {
    						reject(err)
    					}
    				});
    			})
    		}
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    三、async/await与Promise.all()结合使用

    因为Promise.all()返回的也是Promise,所以await 后面可以跟Promise.all()

             function fn() {
    			return new Promise((resolve, reject) => {
    				resolve(Math.random())
    			})
    		}
    		async function asyncFunc() {
    			let result
    			try {
    				result = await Promise.all([fn(), fn()])
    				console.log(result)
    			} catch (err) {
    				console.log(err, 'err')
    			}
    			return result
    		}
          asyncFunc().then(res => { console.log(res, 'res') })
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
  • 相关阅读:
    PHP文字识别Tesseract (CentOS)
    fegin调用关于session,请求头传递参数问题
    SLA 、SLO & SLI
    UE4 相机围绕某点旋转
    基础ArkTS组件:二维码,滚动条与滑动条,多选框与多选框群组(HarmonyOS学习第三课【3.4】)
    【解决方案】智慧体育场馆大场景安防视频监控,可持续性保障大型场馆安全运行
    kubernetes架构及核心组件简单介绍
    【ACM学习】【STL】顺序容器的特性比较(不包括array)
    力扣235和236 二叉树的最近公共祖先问题
    人工智能已经帮助世界各地的研究人员推断远远超出人类认知能力范围的关系
  • 原文地址:https://blog.csdn.net/qq_38951259/article/details/127975020
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号