promise的三种状态_一.Promise中核心逻辑的实现
生活随笔
收集整理的這篇文章主要介紹了
promise的三种状态_一.Promise中核心逻辑的实现
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
首先看一下Promise代碼:
let promise =new Promise((resolve,reject)=>{resolve('成功');//reject('失敗'); }) promise.then(val=>{console.log(val); },reason=>{console.log(reason); })我們根據以上的一個簡單的用例,得到Promise類的最主要的核心邏輯,分為以下幾個方面:
根據以上得到的部分結論,我們可以實現以下代碼:
//常量定義三種狀態 以防拼錯與進行代碼提示。 const PENDING='pending'; const FULFILLED='fulfilled'; const REJECTED='rejected';class MyPromise{//執行器constructor(executor){//當前函數this指定MyPromise對象this.resolve=this.resolve.bind(this);this.reject=this.reject.bind(this);//默認狀態this.status=PENDING;//成功返回數據this.value=undefined;//失敗返回原因this.reason=undefined;//執行執行器executor(this.resolve,this.reject);}//成功執行時的方法resolve(value){//因為狀只能是pending=> fulfilled/rejected 如果其他狀態就返回if(this.status!==PENDING) return;//執行之后狀態更改為fulfilledthis.status=FULFILLED;//把成功返回值保存在變量里邊this.value=value;}//失敗執行方法reject(reason){if(this.status!==PENDING) return;this.status=REJECTED;//把失敗返回值保存在變量里邊this.reason=reason;}//then方法執行then(sucessCallback,failCallback){//判斷狀態 來調用回調函數switch(this.status){case FULFILLED:sucessCallback(this.value);break;case REJECTED:failCallback(this.reason);break;default:break;}} }我們可以調用MyPromise類來實現文章開頭代碼所展示的功能。
let promise=new MyPromise((resolve,reject)=>{//resolve('成功');reject('失敗'); }); promise.then(val=>{console.log(val); },reason=>{console.log(reason); })目前我們只實現了一個簡單的同步調用邏輯,如果代碼中有異步操作,需要怎么實現呢?
let promise=new MyPromise((resolve,reject)=>{setTimeout(() => {resolve('成功');}, 1000);//reject('失敗'); }); promise.then(val=>{console.log(val); },reason=>{console.log(reason); })請看下篇文章
李先生:二.Promise中異步邏輯的實現?zhuanlan.zhihu.com總結
以上是生活随笔為你收集整理的promise的三种状态_一.Promise中核心逻辑的实现的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: A* 寻路 +寻路演示(js)
- 下一篇: 自定义处理网页选区字符并实时显示(js)