Promise源码的个人理解

所谓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);
}
}

你可能感兴趣的:(js,vue)