Promise手写源码

class PYCPromise{
  static PENDING = 'pending'
  static FULFILED = 'fulfiled'
  static REJECTED = 'rejected'
  constructor(executor){
    this.status = PYCPromise.PENDING;
    this.value = null;
    this.callbacks = [];
    try {
      executor(this.resolve.bind(this), this.reject.bind(this));
    } catch (error) {
      this.reject(error);
    }
  }
  resolve(value){
    if(this.status == PYCPromise.PENDING){
      this.status= PYCPromise.FULFILLED
      this.value = value
      setTimeout(()=>{
        this.callbacks.map(item => {
          item.onFulfilled(this.value)
        })
      })
    }
  }
  reject(value){
    if(this.status == PYCPromise.PENDING){
      this.status= PYCPromise.FULFILLED
      this.value = value
      setTimeout(()=>{
        this.callbacks.map(item => {
          item.onRejected(this.value)
        })
      })
    }
  }
  then(onFulfilled,onRejected){
    if(typeof onFulfilled != 'function'){
      onFulfilled = (value)=>value
    }
    if(typeof onRejected != 'function'){
      onRejected = (value)=>{value}
    }
    let promise =  new PYCPromise((resolve,reject)=>{
      if(this.status == PYCPromise.PENDING){
        this.callbacks.push({
          onFulfilled:(value)=>{
            this.parse(promise,onFulfilled(value),resolve,reject)
          },
          onRejected:(value)=>{
             this.parse(promise,onRejected(value),resolve,reject)
          }
        })
      }
      if(this.status == PYCPromise.FULFILLED){
        setTimeout(()=>{
          this.parse(promise,onFulfilled(this.value),resolve,reject)
        })
      }
      if(this.status == PYCPromise.REJECTED){
        setTimeout(()=>{
          this.parse(promise,onRejected(this.value),resolve,reject)
        })
      }
    })
    return promise;
  }
  parse(promise,result,resolve,reject){
    if(promise == result){
      throw new Error('不能使用同一个promise')
    }
     try {
      if(result instanceof PYCPromise){
        result.then(resolve,reject)
      }else{
        resolve(result)
      }
     } catch (error) {
      reject(error)
     }
  }

  static all(promises){
    let values = []
    return new PYCPromise((resolve,reject)=>{
      promises.forEach(promise => {
        promise.then((value)=>{
          values.push(value)
          if(values.length === promises.length){
            resolve(values)
          }
        },(reason)=>{
          reject(reason)
        })
      });
    })
  }
  static race(promises){
    return new PYCPromise((resolve,reject)=>{
      promises.map(promise =>{
        promise.then((value)=>{
          resolve(value)
        },reason =>{
          reject(reason)
        })
      })
    })
  }

  static resolve(value){
      return new PYCPromise((resolve,reject)=>{
        if(value instanceof PYCPromise){
          value.then(resolve,reject)
        }else{
          resolve(value)
        }
      })
  }
  static reject(value){
    return new PYCPromise((resolve,reject)=>{
       reject(value)
    })
  }





}

new PYCPromise((resolve, reject) => {
  resolve("后盾人");
  console.log("hdcms.com");
})
.then()
.then(
  value => {
    console.log(value);
    return new PYCPromise((resolve,reject)=>{
      resolve('pyc')
    });
  },
  reason => {
    console.log(reason);
  }
)
.then(
  value => {
    console.log(value);
  },
  reason => {
    console.log(reason);
  }
);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值