Promise系列手写题(持续更新中~)

手写 Promise 及 then 方法

原文可可以看 https://juejin.cn/post/7040016523108286494 这篇文章,个人感觉书写的格式梳理的很好

class myPromise {
  status = "pendding";
  value = undefined;
  onResolvedCallbacks = [];
  onRejectedCallbacks = [];
  constructor(exec) {
    const reslove = (value) => {
      const doFn = () => {
        if (this.status !== "pendding") return;
        this.value = value;
        this.status = "resloved";
        while (this.onRejectedCallbacks.length) {
          this.onResolvedCallbacks.shift()();
        }
      };
      setTimeout(doFn, 0);
    };
    const reject = (value) => {
      const doFn = () => {
        if (this.status !== "pedding") return;
        this.value = value;
        this.status = "rejected";
        while (this.onRejectedCallbacks.length) {
          this.onRejectedCallbacks.shift()();
        }
        setTimeout(doFn, 0);
      };
    };
    try {
      exec(reslove, reject);
    } catch (err) {
      reject(err);
    }
  }

  then(onReslove, onReject) {
    onReslove = typeof onReslove === "function" ? onReslove : (res) => res;
    onReject =
      typeof onReject === "function"
        ? onReject
        : (err) => {
            throw err;
          };
    const newPromise = new myPromise((reslove, reject) => {
      // 统一处理函数
      const execFun = (fn, val) => {
        try {
          let res = fn(val);
          if (newPromise === res) {
            reject(new TypeError("回调地狱!!"));
            return;
          }
          if (res instanceof myPromise) {
            myPromise.then(reslove, reject);
          } else {
            reslove(res);
          }
        } catch (err) {
          reject(err);
        }
      };

      const success = () => {
        execFun(onReslove, this.value);
      };

      const failed = () => {
        execFun(onReject, this.value);
      };

      if (this.status === "pending") {
        this.onResolvedCallbacks.push(success);
        this.onRejectedCallbacks.push(failed);
      } else if (this.status === "reslove") {
        success();
      } else {
        failed();
      }
    });

    return newPromise;
  }
}

手写 promise.map 方法,控制并发数量限制

第一个 for 循环 limit 同步,每次执行 limit 个,当执行完当前的 promise,会进入下一个 next

function promiseMap(list, fn, limit = Infinity) {
  return new Promise((reslove) => {
    let ret = [];
    let index = -1;
    function next() {
      ++index;
      Promise.resolve(list[index])
        .then((val) => fn(val, index))
        .then((res) => {
          ret.push(res);
          if (ret.length === arr.length) {
            reslove(ret);
          } else if (index < arr.length) {
            next();
          }
        });
    }
    for (let i = 0; i < limit && i < list.length; i++) {
      next();
    }
  });
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

影风莫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值