JavaScript中的Promise.race方法有哪些实用的应用场景?

Promise.race用于获取最先完成的Promise结果,适用于超时控制、最快数据源响应、用户交互优先和检测服务可用性场景。

javascript中的promise.race方法有哪些实用的应用场景?

Promise.race 方法接收一个 Promise 数组,返回一个新的 Promise,这个新 Promise 会在其中任何一个 Promise 首先完成(无论是 resolve 还是 reject)时立即结束,并以那个最先完成的结果或错误作为结果。这种“竞速”机制在一些特定场景下非常实用。

1. 设置超时控制

这是 Promise.race 最常见的用途之一:为异步操作设置最大等待时间。如果目标操作在指定时间内未完成,则用超时逻辑替代。

例如,发起一个网络请求并限制其必须在 5 秒内返回:

const fetchWithTimeout = (url, timeout) => { const controller = new AbortController(); const timeoutId = setTimeout(() => controller.abort(), timeout); const fetchPromise = fetch(url, { signal: controller.signal }); const timeoutPromise = new Promise((_, reject) => setTimeout(() => reject(new Error(‘Request timed out’)), timeout) ); return Promise.race([fetchPromise, timeoutPromise]); }; // 使用 fetchWithTimeout(‘/api/data’, 5000) .then(response => console.log(‘Success:’, response)) .catch(err => console.error(‘Failed:’, err.message));

一旦超时 Promise 先 resolve 或 reject,整个请求就会中断,避免长时间挂起。

立即学习“Java免费学习笔记(深入)”;

2. 获取最快响应的数据源

当有多个相同数据来源的接口(如多个 CDN 或备份服务器),可以使用 race 来获取最快返回的结果,提升用户体验。

比如从两个镜像地址加载资源:

const fastestImageLoad = (urls) => { const promises = urls.map(url => { return new Promise((resolve, reject) => { const img = new Image(); img.onload = () => resolve(url); img.onerror = () => reject(new Error(`Failed to load ${url}`)); img.src = url; }); }); return Promise.race(promises); }; fastestImageLoad([‘/img/a.png’, ‘/backup/img/a.png’]) .then(src => console.log(‘Loaded from:’, src)) .catch(err => console.error(‘All sources failed:’, err));

页面能更快展示内容,尤其在网络不稳定时优势明显。

动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版 动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版

动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包

动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版 508 查看详情 动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版

3. 用户交互优先于自动流程

在某些场景中,你可能启动一个自动操作(如自动跳转或默认选择),但希望用户操作能中断它。

例如,页面 3 秒后自动跳转,但如果用户提前点击按钮,则立即跳转:

const autoRedirect = new Promise(resolve => { setTimeout(() => resolve(‘auto’), 3000); }); const userClick = new Promise(resolve => { document.getElementById(‘skip-btn’).addEventListener(‘click’, () => { resolve(‘user’); }); }); Promise.race([autoRedirect, userClick]).then(action => { console.log(`${action === ‘user’ ? ‘User clicked’ : ‘Auto redirect’}`); navigateToNextPage(); });

这样既保证了自动化,又尊重了用户主动性。

4. 竞速检测服务可用性

在系统初始化时,可并发检测多个关键服务是否可达,只要有一个快速响应即可继续流程。

比如检查登录状态时尝试多个端点:

Promise.race([ fetch(‘/auth/check-v1’).then(res => res.json()), fetch(‘/auth/check-v2’).then(res => res.json()) ]) .then(status => { if (status.authenticated) proceed(); }) .catch(() => console.warn(‘All auth checks failed’));

适用于高可用架构中“只要有可用节点就行”的场景。

基本上就这些。Promise.race 的核心价值在于“谁快听谁的”,适合用于超时控制、性能优化和用户行为响应等需要快速决策的场合。注意:一旦某个 Promise 完成,其余的并不会被取消,只是不再被关注,因此需注意资源清理问题。

以上就是JavaScript中的Promise.race方法有哪些实用的应用场景?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/736913.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月25日 13:25:14
下一篇 2025年11月25日 13:25:35

相关推荐

  • Redis集群Python客户端该如何选择?

    选择合适的Redis集群Python客户端 在使用Redis集群时,选择合适的Python客户端至关重要。一些曾经流行的库,例如redis-py-cluster,现已停止维护,且版本过低,无法满足现代Redis功能需求。虽然redis-py-cluster的作者声称其功能已整合进redis-py,但…

    2025年12月13日
    000
  • Redis集群Python SDK:如何选择以及最佳实践?

    Python Redis集群SDK现状及选择建议 在开发Redis集群应用时,选择合适的Python SDK至关重要。许多教程使用已停止维护的redis-py-cluster库(最高支持Redis 3.0),这在现代Redis环境中不可取。 需要注意的是,redis-py本身是单机版客户端,无法直接…

    2025年12月13日
    000
  • 如何利用Python装饰器构建灵活的工作流程并实现状态跳转和异常处理?

    利用Python装饰器构建灵活、可维护的工作流程 本文介绍如何利用Python装饰器构建类似有限状态机的灵活工作流程,从而避免传统if-else语句带来的代码冗余和难以维护的问题。 尤其在处理多步骤流程、异常情况和回滚重试时,装饰器能提供更优雅的解决方案。 考虑一个四步工作流程,每步都可能抛出异常或…

    2025年12月13日
    000
  • Python事件驱动编程:如何用asyncio实现高效的异步操作?

    Python异步编程模型详解 本文深入探讨Python的异步编程(Asynchronous Programming),阐述其核心概念、实现方法及应用场景。异步编程是一种编程范式,它与传统的同步编程截然不同:程序的执行流程并非严格按照预定顺序,而是由事件的发生来驱动。程序持续监控各种事件,并在事件触发…

    2025年12月13日
    000
  • JWT多账号登录:如何优雅地处理旧Token失效问题?

    JWT多账号登录下的旧Token失效问题及解决方案 在使用JWT实现多账号登录时,如何优雅地处理旧Token失效是一个常见挑战。许多开发者误认为JWT本身就能解决这个问题,但事实并非如此。 JWT的无状态特性决定了服务器不存储与Token相关的信息,因此JWT自身无法自动使旧Token失效。 多次登…

    2025年12月13日
    000
  • DrissionPage库启动报错:如何解决“参数错误”问题?

    Python库DrissionPage启动报错及解决方案 许多用户在使用DrissionPage库时,启动时可能遇到报错。本文将分析一个具体的报错案例并提供解决方案。该案例中,运行以下代码时出现错误: from drissionpage import chromiumpagepage = chrom…

    2025年12月13日
    000
  • 百度百科网页爬虫XPath提取结果为空,如何解决?

    百度百科网页爬虫XPath提取失败:原因及解决方案 在使用XPath爬取百度百科数据时,经常遇到提取结果为空的情况。本文针对此问题,提供详细的分析和解决方案。 问题通常源于代码未能正确处理百度百科的页面重定向。 许多爬虫程序直接使用初始URL进行请求,而忽略了百度百科返回的302 Found状态码(…

    2025年12月13日
    000
  • JWT多账号登录下如何优雅地处理旧Token失效?

    优雅处理JWT多账号登录下的旧Token失效 在JWT实现多账号登录的应用中,如何有效地使旧Token失效是一个常见挑战。由于JWT的无状态特性,服务端不存储Token状态,无法直接让旧Token失效。 那么,如何规避多账号登录场景下旧Token带来的安全风险呢?关键在于引入外部状态管理机制。JWT…

    2025年12月13日
    000
  • Python事件驱动编程:如何利用asyncio实现高效的异步IO?

    Python事件驱动编程:基于asyncio的异步IO详解 Python的事件驱动编程模型,对于许多开发者而言,常常显得有些抽象。本文旨在深入浅出地讲解Python事件驱动编程的原理,并结合实际案例,帮助您理解其在不同应用场景下的优势。 事件驱动编程的核心在于,程序的运行流程并非由预先设定的顺序决定…

    2025年12月13日
    000
  • Python 实现视频格式转换工具的高效途径

    高效python视频转换的关键在于:1. 使用subprocess.popen()异步调用ffmpeg,避免阻塞主线程,提高效率;2. 利用multiprocessing模块实现多进程并行处理,充分利用多核cpu;3. 合理设置ffmpeg参数(如-crf),并确保充足的内存和硬盘空间,特别是使用s…

    2025年12月13日
    000
  • Python 实现语音识别工具的不同技术方案

    Python 实现语音识别工具的不同技术方案:深度剖析与实践 很多开发者都想过构建一个属于自己的语音识别工具,这听起来很酷,对吧?但实际操作中,你会发现选择合适的技术方案至关重要,它直接影响着你的工具的准确率、效率,甚至最终的易用性。这篇文章,我们就来深入探讨几种 Python 实现语音识别的技术方…

    2025年12月13日
    000
  • Python多进程Pipe管道阻塞:如何解决子进程无法向父进程发送消息的问题?

    Python多进程通信:Pipe管道阻塞及解决方案 在Python多进程编程中,进程间通信至关重要。Pipe管道提供了一种便捷的进程间数据传输机制,但实际应用中可能遇到阻塞问题,例如父进程无法接收子进程发送的消息。本文分析一个典型案例,并提供解决方案。 问题描述: 以下代码尝试使用Pipe管道在父进…

    2025年12月13日
    000
  • Python 数据清洗之 IP 地址字段分类处理教程

    python数据清洗ip地址的关键在于正则表达式。1. 使用re模块的正则表达式匹配函数(如re.match())进行ip地址识别;2. ipv4_pattern匹配ipv4地址格式;3. ipv6_pattern匹配ipv6地址格式,该正则表达式较为复杂,需涵盖多种ipv6表示形式;4. 根据匹配…

    2025年12月13日
    000
  • Python 数据清洗之电子邮件字段验证与清洗教程

    python利用正则表达式库re高效清洗邮件地址。1. 使用正则表达式^[a-za-z0-9._%+-]+@[a-za-z0-9.-]+.[a-za-z]{2,}$验证邮件地址格式,但其并非完美无缺;2. email.strip()去除前后空格,re.sub()去除无效字符,并可根据实际情况添加更复…

    2025年12月13日
    000
  • Python 数据清洗之社交媒体链接字段整理教程

    文章介绍了使用python清洗社交媒体链接的方法,核心步骤如下:1. 使用正则表达式url_pattern匹配并提取有效url;2. 定义clean_social_media_link函数,该函数利用正则表达式清洗链接并进行规范化处理,例如去除参数和空格;3. 将清洗函数应用于待清洗的链接列表,得到…

    2025年12月13日
    000
  • Python 实现图像处理滤镜工具的独特途径

    本文介绍了使用python和numpy、pil库实现图像滤镜的独特方法,而非依赖opencv。其步骤为:1. 使用pil库读取图像并转换为numpy数组;2. 利用numpy数组进行像素操作,例如使用加权平均实现灰度化;3. 对于高级滤镜,如边缘检测,使用scipy.signal.convolve2…

    2025年12月13日
    000
  • Python 数据清洗之日期字段规范化处理教程

    python日期清洗的关键在于将各种格式的日期数据统一成标准格式,例如iso 8601格式。1. 利用pandas的to_datetime函数,结合errors=’coerce’参数处理大部分日期格式,将无法解析的日期转换为nat。2. 对于to_datetime无法处理的特…

    2025年12月13日
    000
  • Python 实现网络爬虫工具的不同策略讲解

    Python 爬虫策略:从菜鸟到老司机的进阶之路 你是否想过,如何用 Python 优雅地从互联网上抓取信息?这篇文章不会教你简单的 requests 库用法,而是深入探讨几种不同的爬虫策略,以及它们背后的权衡和陷阱。读完这篇文章,你将对构建健壮、高效的 Python 爬虫有更深刻的理解,不再是只会…

    2025年12月13日
    000
  • Python 实现文件搜索和替换工具的有效方法

    python高效文件搜索替换方法是:1. 使用os模块遍历文件,re模块利用正则表达式进行精准匹配替换;2. 利用multiprocessing.pool创建进程池,实现多进程并行处理,显著提升效率;3. 可进一步优化,例如:增量式替换减少io操作,备份原始文件防止数据丢失,开发图形界面提升用户体验…

    2025年12月13日
    000
  • Python 中如何对齐和格式化表格数据输出

    python优雅输出表格数据的方法是:1. 使用tabulate库,它轻量且易用,支持多种表格格式(如grid, plain, rst),通过headers和tablefmt参数控制表头和格式;2. 对于字典列表数据,headers=”keys”可直接使用字典键作为表头;3.…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信