Promise 简易实现 - 面试专用

基础使用

// 使用:
function a(){
  return new Promise(function(resolve, reject){
    setTimeout(()=>{
      resolve(true)
    }, 2000)
  })
}
a().then((msg)=>{
  console.log(msg)
  console.log('===msg====')
})

复制代码

脑中清晰Promise提供哪些API

1、构造函数

function Promise(resolver){}
复制代码

2、原型方法

Promise.prototype.then = function(){}
Promise.prototype.catch = function(){}
复制代码

3、静态方法

Promise.resolve = function(){}
Promise.reject = function(){}
Promise.all = function(){}
Promise.race = function(){}
复制代码

构造函数用法总结:
(1) 构造函数接收一个executor立即执行函数
(2) executor立即执行函数接收一个resolve函数
(3) promise对象的then方法绑定状态变为fulfilled时的回调
(4) resolve函数被调用时会触发then方法中的回调

构造函数的简单实现

function testPromise(executor){
  var self = this;
  self.status = 'pending'; // promise 当前的状态
  self.data = undefined; // promise 的值
  self.onResolvedCallback = []; //存多个then 的回调函数  1
  self.onRejectedCallback = []; // 处理reject
  function resolve(value){
    if(self.status === 'pending'){
      self.status = 'resolved'
      self.data = value
      for(var i=0 ;i< self.onResolvedCallback.length; i++ ){
        self.onResolvedCallback[i](value)
      }
    }
  }
  function reject(reason){
    if(self.status === 'pending'){
      self.status = 'rejected';
      self.data = reason
      for(var i=0;i< self.onRejectedCallback.length;i++ ){
        // 收集reject
        self.onRejectedCallback[i] && self.onRejectedCallback[i](reason)
      }
    }
  }
  // executor(resolve) // 立即执行  1
  try{
    executor(resolve, reject)
  }catch(e){
    reject(e)
  }
}
// then  第二个函数是 reject
testPromise.prototype.then = function(resolve, reject){
  // 收集回调函数
  this.onResolvedCallback.push(resolve);
  if(reject){
    this.onRejectedCallback.push(reject)
  }
  return this
}
testPromise.prototype.catch = function(reject){
  if(reject){
    this.onRejectedCallback.push(reject)
  }
  return this
}
复制代码

将promise的resolve和reject异步执行 如果executor 自执行函数中的resolve 函数立即触发时,发现Promise 失效。

const promise = new testPromise((resolve) => {
    resolve(1);
});
promise.then((a) => alert(a));
复制代码

解决办法: 将resolve ,reject 放入到setTimeout 里,即

function testPromise(executor){
  var self = this;
  self.status = 'pending'; // promise 当前的状态
  self.data = undefined; // promise 的值
  self.onResolvedCallback = []; //存多个then 的回调函数  1
  self.onRejectedCallback = []; // 处理reject
  function resolve(value){
    setTimeout(function(){
      if(self.status === 'pending'){
        self.status = 'resolved'
        self.data = value
        for(var i=0 ;i< self.onResolvedCallback.length; i++ ){
          self.onResolvedCallback[i](value)
        }
      }
    })
  }
  function reject(reason){
    setTimeout(function(){
      if(self.status === 'pending'){
        self.status = 'rejected';
        self.data = reason
        for(var i=0;i< self.onRejectedCallback.length;i++ ){
          // 收集reject
          self.onRejectedCallback[i] && self.onRejectedCallback[i](reason)
        }
      }
    })
  }
  // executor(resolve) // 立即执行  1
  try{
    executor(resolve, reject)
  }catch(e){
    reject(e)
  }
}
// then  第二个函数是 reject
testPromise.prototype.then = function(resolve, reject){
  // 收集回调函数
  this.onResolvedCallback.push(resolve);
  if(reject){
    this.onRejectedCallback.push(reject)
  }
  return this
}
testPromise.prototype.catch = function(reject){
  if(reject){
    this.onRejectedCallback.push(reject)
  }
  return this
}
复制代码

3-5年内部岗位(平安、乐信、vivo、oppo)推荐机会,欢迎发简历到: zgxie@126.com

更完整的参考

转载于:https://juejin.im/post/5d0aef815188254ee433d052

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值