vue關(guān)于Promise的使用方式
Promise基本概念
Promise是一個構(gòu)造函數(shù),所以可以 new 出一個Promise的實例;
- 在Promise上有兩個函數(shù) resolve (成功之后的回調(diào)函數(shù))和 reject (失敗后的回調(diào)函數(shù));
- 在Promise構(gòu)造函數(shù)的prototype屬性上,有一個 .then() 方法。
所以只要是Promise構(gòu)造函數(shù)創(chuàng)建的實例,都可以訪問到 .then()方法;
- Promise表示一個一步操作,每當(dāng)我們new一個Promise的實例,這個實例就代表具體的 異步 操作。
- Promise創(chuàng)建的實例,是一個異步操作,這個異步操作結(jié)果,
只有兩種結(jié)果:
- 狀態(tài)1:異步執(zhí)行 成功,需要在內(nèi)部調(diào)用成功的回調(diào)函數(shù)resolve把結(jié)果返回給調(diào)用者
- 狀態(tài)2:異步執(zhí)行 失敗,需要在內(nèi)部調(diào)用失敗的回調(diào)函數(shù)reject把結(jié)果返回調(diào)用者
由于Promise的實例是一個異步操作,所以內(nèi)部拿到操作結(jié)果后,無法使用return把操作結(jié)果返回給調(diào)用者 ,
這個時候只能使用 回調(diào)函數(shù) 的形式,把成功或失敗的結(jié)果,返回給調(diào)用者,
具體:
- 我們可以在new出來的Promise實例上,調(diào)用 .then()方法
- 預(yù)先為這個Promise異步操作,指定成功(resolve)和失敗(reject)回調(diào)函數(shù)
使用實例
store.js的actions中添加increment方法。測試reject的使用方法。
increment (context) { return new Promise((resolve, reject) => { setTimeout(() => { reject(new Error('2222222')) }, 1000) }) }
調(diào)用increment
handleActionDecrease () { this.$store.dispatch('increment').then((data) => { console.log(data) console.log(this.$store.state.count) }).catch((error) => { console.log(error) }) }
返回結(jié)果為
store.js的actions中添加increment方法。
測試resolve的使用方法。
increment ({ commit }) { return new Promise((resolve, reject) => { setTimeout(() => { resolve("1111") reject(new Error('2222222')) }, 1000) }) },
調(diào)用
handleActionDecrease () { this.$store.dispatch('increment').then((data) => { console.log(data) console.log(this.$store.state.count) }).catch((error) => { console.log(error) }) }
輸出
總結(jié)
- resolve —>對應(yīng)then
- reject —>對應(yīng)catch
另外,只有調(diào)用了resolve 或者reject 才會觸發(fā) then 和 catch
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue實現(xiàn)的上拉加載更多數(shù)據(jù)/分頁功能示例
這篇文章主要介紹了vue實現(xiàn)的上拉加載更多數(shù)據(jù)/分頁功能,涉及基于vue的事件響應(yīng)、數(shù)據(jù)交互等相關(guān)操作技巧,需要的朋友可以參考下2019-05-05基于vue-element組件實現(xiàn)音樂播放器功能
這篇文章主要介紹了基于vue-element組件實現(xiàn)音樂播放器功能,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧2018-05-05vue與django(drf)實現(xiàn)文件上傳下載功能全過程
最近簡單的學(xué)習(xí)了django和drf上傳文件(主要是圖片),做一個記錄,下面這篇文章主要給大家介紹了關(guān)于vue與django(drf)實現(xiàn)文件上傳下載功能的相關(guān)資料,需要的朋友可以參考下2023-02-02vuejs2.0運用原生js實現(xiàn)簡單拖拽元素功能
這篇文章主要為大家詳細(xì)介紹了vuejs2.0運用原生js實現(xiàn)簡單拖拽元素功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12