Promise 对象的结构是什么样的,它有哪些方法?

一个 Promise 对象代表一个异步操作的最终完成(或失败)及其结果值。它允许你将异步操作的结果与成功时或失败时的回调函数关联起来。

Promise 对象的方法:

  1. Promise.prototype.then(onFulfilled, onRejected) : 添加解析成功和解析失败的回调函数。onFulfilled 是解析成功时调用的函数,onRejected 是解析失败时调用的函数。then 方法返回一个新的 Promise 对象。

  2. Promise.prototype.catch(onRejected) : 添加解析失败的回调函数。这等同于调用 Promise.prototype.then(undefined, onRejected)catch 方法返回一个新的 Promise 对象。

  3. Promise.prototype.finally(onFinally) : 添加一个回调函数,无论 Promise 成功解析还是被拒绝,都将执行该回调。它在 Promise 链中的最后执行,并且返回一个新的 Promise 对象。

静态方法:

  1. Promise.resolve(value) : 返回一个解析为给定值的 Promise 对象。如果传入的值本身就是一个 Promise,它将不会被包装,而是直接返回。

  2. Promise.reject(reason) : 返回一个被拒绝的 Promise 对象,并提供拒绝的原因。

  3. Promise.all(iterable) : 返回一个 Promise,该 Promise 会等待所有传入的 Promise 对象解析完成。如果任何一个传入的 Promise 被拒绝,返回的 Promise 也会立即被拒绝,并返回第一个拒绝的原因。

  4. Promise.allSettled(iterable) : 返回一个 Promise,该 Promise 会等待所有传入的 Promise 对象解析或被拒绝。返回一个新的 Promise 对象,解析为传入的 Promise 对象的最终状态数组。

  5. Promise.race(iterable) : 返回一个 Promise,它将解析或拒绝,具体取决于传入的 Promise 对象中第一个解析或被拒绝的那个。

  6. Promise.any(iterable) : 接收一个 Promise 对象的集合,并返回第一个解析的 Promise 的值。如果所有的 Promise 都被拒绝,则返回一个新的 Promise,包括一个 AggregateError 类型的错误。

注意,Promise 对象不允许外部直接访问其内部状态或值。它们的状态和值只能通过上述方法和回调函数进行访问和操作。

相关推荐
光影少年19 分钟前
react navite 跨端核心原理
前端·react native·react.js
用户8524950718422 分钟前
解密 JavaScript 中的 this:谁才是真正的调用者?
javascript·面试
monologues23 分钟前
Vue 3 渲染器的核心秘密:从 VNode 创建到快速 Diff 算法
前端
奇奇怪怪的23 分钟前
从开发到生产——生成优化、监控、安全与成本
前端
10share23 分钟前
100行代码 模拟实现Vue 响应式系统
前端·vue.js
Heo25 分钟前
Vite进阶用法详解
前端·javascript·面试
狂炫冰美式1 小时前
人均配了AI, 为什么公司还是没变快? 🤔 本质还是分布式系统问题
前端·后端·架构
铁皮饭盒2 小时前
Next.js 风格路由内置?Bun FileSystemRouter 凭啥这么香
javascript
乘风gg2 小时前
多 Agent 不是万能的!搞懂这 5 个原则,少走 1 年弯路!
前端·agent·ai编程
猩猩程序员2 小时前
Vercel 推出 Agent 框架 Eve:让 AI Agent 像写 Web 应用一样简单
前端