Promise源码的个人理解

9 篇文章 0 订阅

所谓Promise,简单来说就是一个容器,里面保存着某个未来才会结束的事件的结果
Promise对象特点:对象的状态不受外界影响
一旦状态改变,就不会再变,任何时候都是这个结果 pending(进行中)—>fulfilled(已成功) pending(进行中)—>rejected(已失败)
三种状态
1.pending(进行中)
2.fulfilled(已成功)
3.rejected(已失败)
常见状态:
resolved(已定型)
rejected(已失败)
优缺点:
优点:可以将异步操作以同步操作的流程表达出来,Promise对象提供统一的接口,使得控制异步操作更加容易
缺点:无法取消Promise,如果不设置回调函数,内部抛出的错误,不会反应到外部

function myPromise(executor) {
this.stare = “pending”;
this.value = undefined;
this.reject = undefined;
let resolve = (value) => {
if (this.stare == “pending”) {
this.value=value;
this.stare=“fulfilled”;
}
}
let reject =(reject)=>{
if (this.stare == “pending”) {
this.reject=reject;
this.stare=“rejected”;
}
}
executor(resolve, reject);
}

myPromise.prototype.then=function (onFullfilled, onRejected) {
if(this.stare==“fulfilled”){
onFullfilled( this.value);
}
if(this.stare==“rejected”){
onRejected(this.reject);
}
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值