自己实现一个Promise方法

 

  // Promise对象中
        // result结果:resolve和reject传的参数 就会作为结果
        class MyPromise {
            constructor(executor) {
                this._state = 'pending';
                this._result = 'undefined';
                this._fulfilledList = [];
                this._rejectedList = [];

                executor && executor(this.resolve.bind(this), this.reject.bind(this));
            }

            resolve(result) {
                if (this._state === 'pending') {
                    this._state = 'fulfilled';
                    this._result = result;
                    const fulfilled = this._fulfilledList.pop();
                    fulfilled && fulfilled(this._result);
                }
            }

            reject(error) {
                if (this._state === 'pending') {
                    this._state = 'rejected';
                    this._result = error;

                    const rejected = this._rejectedList.pop();
                    rejected && rejected(this._result);
                }
            }

            then(onfulfilled, onrejected) {
                // 如果状态为fulfilled
                if (this._state === 'fulfilled') {
                    return new MyPromise((resolve, reject) => {
                        // 获取onfulfilled的返回值
                        let result = onfulfilled(this._result);

                        // 如果发现返回值是Promise对象的实例 就做如下效果
                        if (result instanceof MyPromise) {
                            // 核心代码:把返回的new Promise的状态 和 result的状态进行关联跟着result的来
                            result.then(resolve, reject);
                        } else {
                            // 如果发现result是非promise对象 那就之间改变 new Promise的状态为fullfilled (通过调用resolve)
                            resolve(result);
                        }
                    });
                    // 如果状态是rejected
                } else if (this._state === 'rejected') {
                    return new MyPromise((resolve, reject) => {
                        let result = onfulfilled(this._result);

                        // 如果发现返回值是Promise对象的实例 就做如下效果
                        if (result instanceof MyPromise) {
                            // 核心代码:把返回的new Promise的状态 和 result的状态进行关联跟着result的来
                            result.then(resolve, reject);
                        } else {
                            // 如果发现result是非promise对象 那就之间改变 new Promise的状态为fullfilled (通过调用reject)
                            reject(result);
                        }
                    })
                } else if (this._state === 'pending') {
                    return new MyPromise((resolve, reject) => {
                        // 这个地方因为考虑到 实例中的状态还是pending 所以不能立即执行onfulfilled和onrejected
                        // 而是要把对于的代码 放在一个函数中,交由 this._fulfilled 中进行保存,在状态发生改变的地方 (如this.resolve方法中)
                        this._fulfilledList.push(() => {
                            // 这里面的逻辑 和上面的一样 获取onfulfilled的返回值
                            let result = onfulfilled(this._result);
                            // 如果发现返回值是Promise对象的实例 就做如下效果
                            if (result instanceof MyPromise) {
                                // 核心代码:把返回的new Promise的状态 和 result的状态进行关联跟着result的来
                                result.then(resolve, reject);
                            } else {
                                // 如果发现result是非promise对象 那就之间改变 new Promise的状态为fullfilled (通过调用resolve)
                                resolve(result);
                            }
                        });
                        this._rejectedList.push(() => {
                            let result = onrejected(this._result);

                            if (result instanceof MyPromise) {
                                result.then(resolve, reject);
                            } else {
                                // 1.hello
                                resolve(result);
                            }
                        });
                    })
                }
            }
        }

        let p = new MyPromise((resolve, reject) => {
            console.log('立即执行');
            // resolve('成功');
            // reject('失败');
            setTimeout(() => {
                reject('成功1');
            }, 1000)
        })
        console.log(p);
        p.then(data => {
            console.log(data);
            return 2;
        }, error => {
            console.log(error);
            return 4;
        }).then(data => {
            console.log(data);
            return new MyPromise((resolve) => {
                setTimeout(() => {
                    resolve(3);
                }, 1000)
            })
        }).then(data => {
            console.log(data);
        })

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现Promise的基本思路如下: 1. 创建一个Promise类,它具有resolve、reject、then、catch等方法 2. 在Promise类中定义一个状态变量,可以是pending、fulfilled、rejected中的一种 3. 定义一个存储回调函数的数组,当Promise状态发生改变时,会执行这些回调函数 4. 在resolve和reject方法中,改变Promise的状态,并执行相应的回调函数 5. 在then和catch方法中,将回调函数添加到数组中,如果Promise已经完成,则立即执行回调函数,否则等待Promise的状态改变后再执行回调函数 下面是一个简单的Promise实现示例: ```javascript class MyPromise { constructor(executor) { this.status = 'pending'; // 初始状态为pending this.value = null; // 成功时的返回值 this.reason = null; // 失败时的原因 this.handlers = []; // 存储回调函数的数组 executor(this.resolve.bind(this), this.reject.bind(this)); } resolve(value) { if (this.status === 'pending') { this.status = 'fulfilled'; // 改变状态为fulfilled this.value = value; // 保存成功时的返回值 this.handlers.forEach(handler => handler.onFulfilled(value)); // 执行成功的回调函数 } } reject(reason) { if (this.status === 'pending') { this.status = 'rejected'; // 改变状态为rejected this.reason = reason; // 保存失败时的原因 this.handlers.forEach(handler => handler.onRejected(reason)); // 执行失败的回调函数 } } then(onFulfilled, onRejected) { if (typeof onFulfilled !== 'function') { onFulfilled = value => value; } if (typeof onRejected !== 'function') { onRejected = reason => { throw reason }; } return new MyPromise((resolve, reject) => { if (this.status === 'pending') { this.handlers.push({ onFulfilled: value => { try { const result = onFulfilled(value); if (result instanceof MyPromise) { result.then(resolve, reject); } else { resolve(result); } } catch (error) { reject(error); } }, onRejected: reason => { try { const result = onRejected(reason); if (result instanceof MyPromise) { result.then(resolve, reject); } else { resolve(result); } } catch (error) { reject(error); } } }); } else if (this.status === 'fulfilled') { setTimeout(() => { try { const result = onFulfilled(this.value); if (result instanceof MyPromise) { result.then(resolve, reject); } else { resolve(result); } } catch (error) { reject(error); } }, 0); } else if (this.status === 'rejected') { setTimeout(() => { try { const result = onRejected(this.reason); if (result instanceof MyPromise) { result.then(resolve, reject); } else { resolve(result); } } catch (error) { reject(error); } }, 0); } }); } catch(onRejected) { return this.then(null, onRejected); } } ``` 使用示例: ```javascript const promise = new MyPromise((resolve, reject) => { setTimeout(() => { resolve('hello world'); }, 1000); }); promise.then(value => { console.log(value); // 输出'hello world' }).catch(reason => { console.error(reason); }); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值