React之關于Promise的用法
1.Promise是什么?
從用途上來說:
(1)promise主要用于異步計算。
(2)可以將異步操作隊列化,按照期望的順序執(zhí)行,返回符合預期的結(jié)果。
(3)可以在對象之間傳遞和操作promise,幫助我們處理隊列。
從語法上說:
(1)Promise 是一個對象,從它可以獲取異步操作的消息。
(2)Promise 提供統(tǒng)一的 API,各種異步操作都可以用同樣的方法進行處理
2.Promise對象的特點?
對象的狀態(tài)不受外界影響。
Promise對象代表一個異步操作,有三種狀態(tài):
- pending(進行中)
- fulfilled(已成功)
- rejected(已失?。?/li>
只有異步操作的結(jié)果,可以決定當前是哪一種狀態(tài),任何其他操作都無法改變這個狀態(tài)。
一旦狀態(tài)改變,就不會再變,任何時候都可以得到這個結(jié)果。
Promise對象的狀態(tài)變化只有如下2種:
- pending->fulfilled
- pending->rejected
只要這兩種情況發(fā)生,狀態(tài)就凝固,不會再變,會一直保持這個結(jié)果。
說明:如果改變已經(jīng)發(fā)生了,你再對Promise對象添加回調(diào)函數(shù),也會立即得到這個結(jié)果。這與事件(Event)完全不同,事件的特點是,如果你錯過了它,再去監(jiān)聽,是得不到結(jié)果的。
3.Promise的缺點?
無法取消Promise,一旦新建它就會立即執(zhí)行,無法中途取消。如果不設置回調(diào)函數(shù),Promise內(nèi)部拋出的錯誤,不會反應到外部。當處于pending狀態(tài)時,無法得知目前進展到哪一個階段(剛剛開始還是即將完成)
4.Promise的基本用法?
ES6 規(guī)定,Promise對象是一個構造函數(shù),用來生成Promise實例。
const promise = new Promise(function(resolve, reject) { // ... some code if (/* 異步操作成功 */){ resolve(value); // 異步操作成功時調(diào)用,并將異步操作的結(jié)果作為參數(shù)傳遞出去 } else { reject(error); // 異步操作失敗時調(diào)用,并將異步操作的結(jié)果作為參數(shù)傳遞出去 } }); 對promise對象穿出的值進行處理 promise.then(function(value) { // 這兩個函數(shù)都接受Promise對象傳出的值作為參數(shù)。 // success // 成功時,調(diào)用第一個函數(shù) }, function(error) { // failure // 失敗時,調(diào)用第二個函數(shù) }); 或者 promise.then(function(value) { // success // 成功時,調(diào)用第一個函數(shù) }).catch(function(error) { // failure // 失敗時,調(diào)用第二個函數(shù) }); 說明: (1) promise構造函數(shù),接受一個函數(shù)作為參數(shù)。 (2) 這個函數(shù)又有兩個參數(shù),接受 resolve 和 reject 這兩個參數(shù)。 (3) resolve 和 reject 也是函數(shù) resolve 函數(shù)的作用: 將Promise對象的狀態(tài)從pending 變?yōu)?resolved, 在異步操作成功時調(diào)用,并將異步操作的結(jié)果,作為參數(shù)傳遞出去。!!! reject 函數(shù)的作用: 將Promise對象的狀態(tài)從“從 pending 變?yōu)?rejected, 在異步操作失敗時調(diào)用,并將異步操作報出的錯誤,作為參數(shù)傳遞出去。!!!
5.Promise 新建后就會立即執(zhí)行?
componentDidMount() { let p = new Promise((resolve,reject) => { console.log('1') resolve(); }) p.then(result => { console.log('2') }) console.log('3') } // 執(zhí)行結(jié)果: // 1 // 3 // 2 說明: 上面代碼中,Promise 新建后立即執(zhí)行,所以首先輸出的是 1 。 然后,then方法指定的回調(diào)函數(shù),將在當前腳本所有同步任務執(zhí)行完才會執(zhí)行,所以 2 最后輸出。
例子code
componentDidMount() { new Promise(function (resolve, reject) { console.log('start new Promise...'); var timeOut = Math.random() * 2; console.log('set timeout to: ' + timeOut + ' seconds.'); setTimeout(function () { if (timeOut < 1) { console.log('call resolve()...'); resolve('200 OK'); } else { console.log('call reject()...'); reject('timeout in ' + timeOut + ' seconds.'); } }, timeOut * 1000); }).then(function (result) { //這里的參數(shù)result就是resolve方法通過參數(shù)傳出的內(nèi)容 console.log('Done: ' + result); },function (result) { //這里的參數(shù)result就是reject方法通過參數(shù)傳出的內(nèi)容 console.log('Failed: ' + result); }); }
運行結(jié)果:
6.鏈式任務
Promise還可以做更多的事情,比如,有若干個異步任務,需要先做任務1,如果成功后再做任務2,任何任務失敗則不再繼續(xù)并執(zhí)行錯誤處理函數(shù)。
要串行執(zhí)行這樣的異步任務,不用Promise需要寫一層一層的嵌套代碼。有了Promise,我們只需要簡單地寫:
job1.then(job2).then(job3).catch(handleError);
例子code
componentDidMount() { // 0.5秒后返回input*input的計算結(jié)果: function multiply(input) { return new Promise(function (resolve, reject) { console.log('calculating ' + input + ' x ' + input + '...'); setTimeout(resolve, 500, input * input); }); } // 0.5秒后返回input+input的計算結(jié)果: function add(input) { return new Promise(function (resolve, reject) { console.log('calculating ' + input + ' + ' + input + '...'); setTimeout(resolve, 500, input + input); }); } var p = new Promise(function (resolve, reject) { console.log('start new Promise...'); resolve(123); }); p.then(multiply) .then(add) .then(multiply) .then(add) .then(function (result) { console.log('Got value: ' + result); }); }
運行結(jié)果:
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
react配置代理setupProxy.js無法訪問v3.0版本問題
這篇文章主要介紹了react配置代理setupProxy.js無法訪問v3.0版本問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07使用Electron構建React+Webpack桌面應用的方法
本篇文章主要介紹了使用Electron構建React+Webpack桌面應用的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-12-12解決React在安裝antd之后出現(xiàn)的Can''t resolve ''./locale''問題(推薦)
這篇文章主要介紹了解決React在安裝antd之后出現(xiàn)的Can't resolve './locale'問題,本文給大家分享解決方案,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05React hook 'useState' is calle
這篇文章主要為大家介紹了React hook 'useState' is called conditionally報錯解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12