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

JS手写代码篇---Pomise.race

6、promise.race

Promise.race() 静态方法接受一个 promise 可迭代对象作为输入,并返回一个 Promise。这个返回的 promise 会随着第一个 promise 的敲定而敲定。

比如说:

    //   原生promiserace;const p1 = new Promise((resolve, reject) => {setTimeout(() => {resolve("p1");}, 500);});const p2 = new Promise((resolve, reject) => {setTimeout(() => {resolve("p2");}, 100);});Promise.race([p1, p2]).then((value) => {console.log(value); //p1});

手写promise.race:

  • 输入可迭代的数组
  • 输出返回应该promise
  • 第一个完成的话就要全部结束,所以我们要设定标志词
  • 如果传入的不是promise怎么办,使用promise.relove将每个元素转换为Promise,以处理非Promise的情况。

代码如下:

      //  promise.racestatic race(array){// 判断是否为空if(array.length === 0){return ;}// 返回应该鑫的promisereturn new Commitment((resolve , reject) => {// 标志let close = false;// 开始遍历array.forEach((item) =>{Promise.resolve(item).then((res) => {if(!close){close = true;resolve(res);}}).catch((error) => {if(!close){close = true;reject(error);}})})})}

志词

  • 如果传入的不是promise怎么办,使用promise.relove将每个元素转换为Promise,以处理非Promise的情况。

代码如下:

      //  promise.racestatic race(array){// 判断是否为空if(array.length === 0){return ;}// 返回应该鑫的promisereturn new Commitment((resolve , reject) => {// 标志let close = false;// 开始遍历array.forEach((item) =>{Promise.resolve(item).then((res) => {if(!close){close = true;resolve(res);}}).catch((error) => {if(!close){close = true;reject(error);}})})})}
http://www.xdnf.cn/news/9555.html

相关文章:

  • 2024 CKA模拟系统制作 | Step-By-Step | 11、题目搭建-查看可用节点数量
  • Mysql基础增删改查语句
  • XCTF-web-file_include
  • 智慧财务系统:企业数字化转型的核心引擎
  • [yolov11改进系列]基于yolov11引入混合标准卷积与深度可分离卷积GSConv用于轻量化网络的python源码+训练源码
  • Android获取设备信息
  • github actions入门指南
  • .NET 9正式发布,亮点是.NET Aspire和AI
  • Linux `vi/vim` 编辑器深度解析与高阶应用指南
  • Golang | 搜索哨兵-对接分布式gRPC服务
  • vue修改配置文件.env.development不生效
  • 2025-05-28 学习记录--Python-文件
  • 对象检测新纪元:D-FINE 模型超越 YOLO,带来更精准的实时检测!
  • 6.2 Q1|哈尔滨医科大学GBD发文 | 1990 年至 2019 年颗粒物污染导致的中风全球趋势和负担
  • Python后端开发实战:从0到1搭建高可用API服务
  • 医疗器械企业批记录数字化转型实操指南
  • LeetCode hot100-6
  • C# 基于 Windows 系统与 Visual Studio 2017 的 Messenger 消息传递机制详解:发布-订阅模式实现
  • Python 包管理工具 uv的一些常用指令
  • AWS 创建VPC 并且添加权限控制
  • CloudCompare——点云统计滤波
  • element ui 表格 勾选复选框后点击分页不保存之前的数据问题
  • Service Worker介绍及应用(实现Web Push机制)
  • 【AI学习笔记】Coze平台实现生成小红书热门多图笔记
  • Metasploit工具使用详解(上)丨小白WEB安全入门笔记
  • 电子电路:什么是C类放大器?
  • ⚡️ Linux 系统安装与配置 Git
  • Windows SMB压缩在低速或者高延迟环境可以帮助提供性能增益
  • Linux驱动学习笔记(十)
  • vue-04(深入了解 props:验证、类型和默认值)