织梦做的网站怎么上传视频教程长春网站建设联系吉网传媒优

张小明 2026/1/2 11:03:05
织梦做的网站怎么上传视频教程,长春网站建设联系吉网传媒优,长沙有做网站的吗,网站 系统概述基础问答问#xff1a;有使用过 Promise.race 吗#xff0c;说说他的作用。答#xff1a;Promise.race 接收一个 Promise 数组#xff08;或者一个具有迭代器的对象#xff09;作为参数#xff0c;返回一个新的Promise#xff0c;这个新的 Promise 结果是数组中第一个状…基础问答问有使用过 Promise.race 吗说说他的作用。答Promise.race 接收一个 Promise 数组或者一个具有迭代器的对象作为参数返回一个新的Promise这个新的 Promise 结果是数组中第一个状态变更的Promise对象无所谓这个状态是否是成功fulfilled还是失败rejected。后续Promise数组中的其他Promise对象状态变更都不再关注。扩展延伸Promise 基础Promise 是 ES6 引入的异步编程解决方案用于表示一个异步操作的最终完成或失败及其结果值。它的核心价值是解决 “回调地狱”将嵌套的回调逻辑转为链式调用then链代码更清晰统一异步操作接口无论异步操作是 “成功” 还是 “失败”都通过统一的 Promise 对象处理避免回调函数分拆如成功回调、失败回调分离。Promise 有且仅有三种状态且状态变化是单向不可逆的这三种状态分别是pending等待态初始状态异步操作未完成fulfilled成功态异步操作完成Promise 状态从pending转为fulfilled并携带成功结果valuerejected失败态异步操作失败Promise 状态从pending转为rejected并携带失败原因reason。这是 Promise 的核心特性也是所有方法设计的基础。状态变化规则只能从pending转为fulfilled或从pending转为rejected一旦状态转为fulfilled或rejected就会 “凝固”后续无法再改变状态状态变化时会触发对应的回调函数then的成功回调、catch的失败回调。Promise 的核心实例方法then 方法处理成功 / 失败结果catch 方法专门处理失败结果catch(onRejected) 等价于then(null, onRejected)是处理rejected状态的语法糖finally 方法无论成功失败都执行Promise静态方法除了Promise.racePromise 还有Promise.all/Promise.allSettled/Promise.resolve/Promise.reject 等静态方法差异点见下表方法 核心作用 状态触发条件 返回值格式 适用场景Promise.race 多个 Promise 竞争取第一个完成的结果 任意一个 Promise 改变状态fulfilled/rejected立即触发对应状态 单个值第一个 Promise 的 value/reason 超时控制、请求降级Promise.all 等待所有 Promise 成功取全部结果 所有 Promise 都 fulfilled才触发 fulfilled任意一个 rejected立即触发 rejected 数组按原数组顺序排列的所有 value 并行请求多个无依赖接口如加载页面资源Promise.allSettled 等待所有 Promise 完成取全部结果无论成败 所有 Promise 都改变状态fulfilled/rejected才触发 fulfilled 数组每个元素含 status 和 value/reason 需知道所有请求结果如批量操作日志Promise.resolve 快速创建一个 fulfilled 状态的 Promise 无直接返回 fulfilled 状态的 Promise 单个 value参数值或参数 Promise 的 value 统一 Promise 格式、转换同步值为异步Promise.reject 快速创建一个 rejected 状态的 Promise 无直接返回 rejected 状态的 Promise 单个 reason参数值 快速抛出异步错误与 async/await 的关系async/await 本质是 Promise 的语法糖。async 函数修饰的函数返回值必然是 Promise若 return 非 Promise 值会用Promise.resolve()包装await 关键字本质是 “等待 Promise 状态变化” 的语法糖只能在 async 函数内部使用后面跟 Promise 对象会暂停 async 函数执行直到 Promise 状态转为fulfilled并将value作为 await 表达式的结果如果 Promise 状态转为rejected会抛出错误需用try/catch捕获等价于 Promise 的catch。面试追问知道定义能手写一个 Promise.race 方法吗/*** 手写Promise.race* param {Iterable} iterable - 可迭代对象如数组* returns {Promise} - 新的Promise对象*/function myPromiseRace(iterable) {// 1. 边界处理参数必须是可迭代对象检查是否有Symbol.iterator方法if (typeof iterable[Symbol.iterator] ! function) {return new Promise((_, reject) {reject(new TypeError(Promise.race() 参数必须是可迭代对象));});}// 2. 返回新Promisereturn new Promise((resolve, reject) {// 3. 遍历可迭代对象用for...of兼容所有可迭代对象for (const item of iterable) {// 4. 用Promise.resolve包装item处理非Promise元素Promise.resolve(item).then((value) {// 一旦有元素成功立即resolve新Promise后续元素不再处理resolve(value);}).catch((reason) {// 一旦有元素失败立即reject新Promise后续元素不再处理reject(reason);});}});}Promise 还有什么方法有什么差异参考扩展延伸部分一个 Promise 可以多次 resolve 吗可以多次执行 resolve 或 reject但是 Promise 的状态只会改变一次就是第一次执行 resolve的时候后续虽然会执行 resolve但是不影响状态没有作用。用 Promise.race 实现超时控制时若超时后原请求仍在继续会有什么问题如何解决出现资源浪费Promise.race 仅感知超时并返回结果但是原请求依旧会继续执行可以结合axios的CancelToken或AbortController取消请求去中断。如何用 Promise 实现‘重试机制’比如接口请求失败后重试 3 次每次间隔 2 秒。/*** Promise重试机制* param {Function} requestFn - 请求函数返回Promise* param {number} maxRetry - 最大重试次数* param {number} interval - 重试间隔毫秒* param {number} currentRetry - 当前重试计数默认0内部使用* returns {Promise} - 最终请求结果*/function promiseRetry(requestFn, maxRetry 3, interval 2000, currentRetry 0) {return new Promise((resolve, reject) {requestFn().then(resolve) // 请求成功直接返回结果.catch((err) {// 若已达最大重试次数抛出最终错误if (currentRetry maxRetry) {reject(new Error(重试${maxRetry}次后仍失败${err.message}));return;}// 未达最大次数延迟后重试console.log(请求失败${interval}ms后重试第${currentRetry1}次);setTimeout(() {// 递归调用当前重试计数1promiseRetry(requestFn, maxRetry, interval, currentRetry 1).then(resolve).catch(reject);}, interval);});});}// 调用示例请求失败后重试3次每次间隔2秒const fetchData () {// 模拟接口请求50%概率失败return new Promise((resolve, reject) {setTimeout(() {if (Math.random() 0.5) {resolve(请求成功结果);} else {reject(new Error(接口返回错误));}}, 1000);});};promiseRetry(fetchData, 3, 2000).then((res) console.log(最终结果, res)).catch((err) console.log(最终失败, err.message));
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

做招投标网站中国移动的网站模板

FaceFusion 支持云存储直连吗?Google Drive/S3 接入实测在处理高清视频换脸任务时,你是否曾因本地磁盘爆满而被迫中断渲染?或者团队成员反复上传同一组素材,只为跑一次模型?这正是许多使用 FaceFusion 的开发者和内容创…

张小明 2026/1/1 22:43:55 网站建设

网站开发工作好找吗开发个网站开票名称是什么

还在为Shutter Encoder在macOS上的各种权限报错而抓狂吗?🤯 别担心,今天我就带你彻底攻克这个技术难题,让你在Mac上畅快使用这款强大的视频压缩工具! 【免费下载链接】shutter-encoder A professional video compressi…

张小明 2025/12/31 22:06:12 网站建设

上海网络营销网站建设成都网站设计开发公司

中医药AI革命:从零构建专业级中医大模型的完整指南 【免费下载链接】Awesome-Chinese-LLM 整理开源的中文大语言模型,以规模较小、可私有化部署、训练成本较低的模型为主,包括底座模型,垂直领域微调及应用,数据集与教程…

张小明 2025/12/31 22:07:47 网站建设

网站建设 国家技术规范北京网站建设公司哪个最好

在新能源行业风起云涌的当下,一家初创公司能否快速组建起一支高质量的研发团队,往往决定了其在激烈市场竞争中的生死存亡。当某新能源初创公司找到我们时,他们面临着这样的困境:产品技术路线已经明确,市场窗口期只有6个…

张小明 2025/12/31 1:24:17 网站建设

一般建设网站大概需要多少钱百度做一个网站多少钱

清华镜像加速Miniconda conda install命令实测报告 在人工智能项目开发中,最让人抓狂的瞬间之一莫过于——当你兴致勃勃准备跑通一个新模型时,conda install pytorch 却卡在“Solving environment”半小时不动,或者下载速度稳定在80 KB/s&am…

张小明 2025/12/31 8:22:52 网站建设

西安建设工程中心交易网站天津实体店网站建设

Trae编辑器中嵌入EmotiVoice插件的可行性研究 在游戏对话系统或有声书创作的工作流中,一个长期存在的痛点是:文本写好了,却要等几天才能听到配音。策划反复修改台词时,每次调整都意味着重新走一遍“提交—录音—返修”的流程&…

张小明 2025/12/30 10:52:37 网站建设