JavaScript的Promise源码解析

在 JavaScript 中,Promise 是一种用于处理异步操作的对象,它提供了一种更优雅的方式来处理异步代码,避免了回调地狱的问题。下面是对 JS 的 Promise 源码的详细解析:

一、Promise 的基本结构

一个 Promise 对象主要包含以下几个部分:

  1. 状态:Promise 有三种状态,分别是 pending(等待中)、fulfilled(已成功)和 rejected(已失败)。初始状态为 pending,一旦状态确定就不可再改变。
  2. 值:当 Promise 状态变为 fulfilled 时,会有一个值与之对应;当状态变为 rejected 时,会有一个原因(reason)与之对应。
  3. 回调函数队列:分别用于存储当 Promise 状态变为 fulfilled 或 rejected 时要执行的回调函数。

以下是一个简单的 Promise 实现框架:

function Promise(executor) {
   
   
  const self = this;
  self.status = "pending";
  self.value = undefined;
  self.reason = undefined;
  self.onResolvedCallbacks = [];
  self.onRejectedCallbacks = [];

  function resolve(value) {
   
   
    if (self.status === "pending") {
   
   
      self.status = "fulfilled";
      self.value = value;
      self.onResolvedCallbacks.forEach((fn) => fn());
    }
  }

  function reject(reason) {
   
   
    if (self.status === "pending") {
   
   
      self.status = "rejected";
      self.reason = reason;
      self.onRejectedCallbacks.forEach((fn) => fn());
    }
  }

  try {
   
   
    executor(resolve, reject);
  } catch (e) {
   
   
    reject
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值