1. Implement simple promise features
SetTimeout (()=>{res(' successful '); },3000) // rej(' failed '); }); Then ((res)=>{console.log(' first output: ',res); },(rej)=>{ console.log(rej); }) p1.then((res)=>{console.log(' second output: ',res); },(rej)=>{ console.log(rej); })Copy the code
Implement the promise functionality manually, namely listening for asynchronous tasks. The following is the encoding implementation:
class Promise1 { _status = 'pending'; OnResolve = []; Reject = []; // Reject = []; constructor(fn){ this.fulfilled = this.fulfilled.bind(this); this.rejected = this.rejected.bind(this); fn(this.fulfilled,this.rejected); SetTimeout (()=>{if (this._status = 'pending'){this._status = 'fulfill'; this.onResolve.forEach((item)=>{ item(val); If (this._status = 'pending'){this._status = 'reject'; if (this._status = 'pending'){this._status = 'reject'; this.onReject.forEach((item)=>{ item(val); })})} then(res,rej){// Subscribe event this.onresolve.push (res); this.onReject.push(rej); }}Copy the code
Results display: after 3 seconds display:During code execution, the constructor is first executed, and the resolve and reject functions are passed in. Resolve and REJECT, because they are asynchronous functions, are placed in the task queue, waiting for the completion of the synchronous task. Therefore perform first then method, analogy to release a subscription model, then method is actually the subscriber will himself () failure and success callback function in function in the list, then after the method performs, execute asynchronous operations right now, if it is successful, will traverse the success of all function in the callback function, and the data to them, Failure iterates over all functions in the failed callback function collection.