When the THEN method performs callbacks, it performs different callbacks based on different states
function Promise(executor){
// Resolve and reject are functions
// Add attributes
this.PromiseState = "pending";
this.PromiseResult = null
const self = this;
/ / resolve function
function resolve(data){
if(self.PromiseState ! = ='pending') return
// (1) Change the state of the object
// this.promisestate // This is window because resolve is called directly
self.PromiseState = 'fulfilled'
// (2) Set the object result value
self.PromiseResult = data
}
/ / reject function
function reject(data){
if(self.PromiseState ! = ='pending') return
// (1) Change the state of the object
self.PromiseState = 'rejected'
// (2) Set the object result value
self.PromiseResult = data
}
// Call the executor function synchronously
try {
executor(resolve,reject)
}catch(e){
reject(e)
}
}
// Add the then method
Promise.prototype.then = function(onResolved,onRejected){
if(this.PromiseState == 'fulfilled'){
onResolved(this.PromiseResult)
}
if(this.PromiseState == 'rejected'){
onRejected(this.PromiseResult)
}
}
Copy the code