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();
    }
  });
}
JavaScriptPromise是一种处理异步操作的对象,它允许你将异步操作写得更加接近同步代码的形式,这样代码更加清晰易懂。Promise有三种状态:pending(等待)、fulfilled(已成功)和rejected(已失败)。一旦Promise被解决(fulfilled或rejected),它就固定在那个状态,不能再次改变。 以下是几个常见的JavaScript Promise面试: 1. Promise的`.then()`方法和`.catch()`方法分别有什么作用? `.then()`方法用于处理Promise成功后的回调函数,它可以接受两个参数,第一个参数是Promise成功时调用的函数,第二个参数是可选的,如果Promise被拒绝(rejected),则调用的函数。`.catch()`方法则专门用来处理Promise被拒绝的情况。 2. 如何创建一个Promise? 可以通过new Promise()构造函数来创建一个新的Promise实例。构造函数接受一个执行器(executor)函数作为参数,该函数接受两个参数:resolve和reject。resolve和reject都是函数,分别用来将Promise的状态从pending改为fulfilled或rejected。 ```javascript let promise = new Promise((resolve, reject) => { // 异步操作代码 if (/* 成功条件 */) { resolve("操作成功"); } else { reject("操作失败"); } }); ``` 3. 如何同时运行多个异步操作,并在它们全部完成后再执行后续操作? 可以使用`Promise.all()`方法。它接受一个Promise对象的数组作为参数,只有所有的Promise都成功解决后,它才会解决;如果任何一个Promise被拒绝,它就会被拒绝。 ```javascript let promise1 = Promise.resolve(3); let promise2 = 42; let promise3 = new Promise((resolve, reject) => { setTimeout(resolve, 100, 'foo'); }); Promise.all([promise1, promise2, promise3]).then(values => { console.log(values); // [3, 42, "foo"] }); ``` 4. 如何处理Promise发生的错误? 可以在`.then()`方法之后连着使用`.catch()`方法来捕获和处理错误。如果在`.then()`发生的任何错误,都会被传递到下一个`.catch()`。 ```javascript promise .then(result => { // 处理结果 }) .catch(error => { // 处理错误 }); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

影风莫

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

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

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

打赏作者

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

抵扣说明:

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

余额充值