前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【笔记】实现一个简易的Promise

【笔记】实现一个简易的Promise

作者头像
SmileSmith
发布2018-04-24 16:17:35
5700
发布2018-04-24 16:17:35
举报
文章被收录于专栏:向前进向前进
代码语言:javascript
复制
const PENDING_STATE = "pending";
const FULLFILL_STATE = "fullfilled";
const REJECTED_STATE = "refected";

class Promise {
  constructor(executor) {
    if (typeof executor !== "function") {
      throw new Error("Promise executor must be a function.");
    }
    this.__state = PENDING_STATE;
    this.__chains = [];

    const resolve = res => {
      // 当且仅当状态是 pending 状态时才可以调用resolve或者reject,防止二次调用。
      if (this.__state !== PENDING_STATE) return;

      // resolve要处理promise,判断是否有then属性
      if (res && typeof res.then === "function") {
        return res.then();
      }

      this.__state = FULLFILL_STATE;
      this.__internalValue = res;

      for (const { onFullFilled } of this.__chains) {
        onFullFilled(res);
      }
    };

    const reject = err => {
      if (this.__state !== PENDING_STATE) return;
      this.__state = REJECTED_STATE;
      this.__internalValue = err;

      for (const { onRejected } of this.__chains) {
        onRejected(err);
      }
    };

    // 规范中,Promise初始化就调用executor
    try {
      executor(resolve, reject);
    } catch (err) {
      // 如果处理器函数抛出一个同步错误,我们认为这是一个失败状态
      reject(err);
    }
  }

  then(onFullFilled, onRejected) {
    return new Promise((resolve, reject) => {
      // 参考上述的constructor实现
      const _onFullFilled = res => {
        try {
          resolve(onFullFilled(res));
        } catch (err) {
          reject(err);
        }
      };

      const _onRejected = err => {
        try {
          reject(onRejected(res));
        } catch (err) {
          reject(err);
        }
      };

      if (this.__state === FULLFILL_STATE) {
        _onFullFilled(this.__internalValue);
      } else if (this.__state === REJECTED_STATE) {
        _onRejected(this.__internalValue);
      } else {
        this.__chains.push({
          onFullFilled: _onFullFilled,
          onRejected: _onRejected
        });
      }
    });
  }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-04-23 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档