學(xué)習(xí)Promise前我們先搞清楚這幾個(gè)單詞。
promise,resolve,reject =>?承諾,解決,失敗。
pending(進(jìn)行中)、fulfilled(已成功)和rejected(已失敗)
不是我裝逼,只是為了你們別太low,自己谷歌一下這幾個(gè)單詞,然后好好發(fā)音,別發(fā)出撲若miss這種中不中西不西的奇怪發(fā)音。
====================================================================================================
關(guān)鍵詞:異步編程。
隨著前端語(yǔ)言的進(jìn)化promise才誕生,現(xiàn)在已經(jīng)統(tǒng)一了并且通用各大瀏覽器和規(guī)則。是異步編程截止18年來(lái)最好的解決方式之一。
ES6 規(guī)定,Promise對(duì)象是一個(gè)構(gòu)造函數(shù),用來(lái)生成Promise實(shí)例。
先來(lái)一個(gè)小例子,抄襲自阮一峰:
function timeout(ms){
????return new Promise((resolve, reject) => {
????????setTimeout(resolve,ms,'done')
????})
}
timeout(2000).then((value) => { console.log(value) })
// => 兩秒后打印出done
大概就是我給一個(gè)承諾,什么是承諾和諾言,可不是男人說(shuō)的愛(ài)你一萬(wàn)年,程序是老實(shí)的,人家說(shuō)我答應(yīng)你執(zhí)行這個(gè)就一定會(huì)執(zhí)行,不執(zhí)行我就會(huì)被干掉。那么實(shí)際例子中呢?
需求,當(dāng)報(bào)銷人改變我們需要做出一系列操作(異常麻煩和繁瑣)
問(wèn)題:因?yàn)楫惓B闊┑牟僮骱蛿?shù)據(jù)需要一定執(zhí)行時(shí)間,這個(gè)時(shí)候我們一個(gè)關(guān)鍵數(shù)據(jù)后臺(tái)最少要400毫秒后才能返回,而我們的一系列操作都基于這個(gè)數(shù)據(jù),這些操作就不干了,誰(shuí)尼瑪?shù)饶氵@么久,我們報(bào)錯(cuò)去了。所以我們這會(huì)兒需要做一個(gè)異步來(lái)解決這個(gè)問(wèn)題,也就是必須先拿到這個(gè)數(shù)據(jù)后才能執(zhí)行其他操作。
方法:
initData(){
? ? return new Promise(){
? ? ? ? getData().then().catch();// 請(qǐng)求后臺(tái)獲取數(shù)據(jù)
? ? ? ? resolve();
????}
}
改變事件調(diào)用,
initData().then(()=>{
? ? 執(zhí)行七七八八的操作。
}).catch()
關(guān)于Promis,自帶then()// 成功;catch()// 失敗;finally();// 成功和失敗都會(huì)執(zhí)行;all();race();//?多個(gè) Promise 實(shí)例,reject();//?返回一個(gè)新的 Promise 實(shí)例
面試題:抄襲自不知名網(wǎng)友,想知道正確答案請(qǐng)留言。
// 理解promise嘗試得出打印結(jié)果,想知道答案的留言問(wèn)我。
setTimeout(function() { console.log(1) }, 0);
new Promise(function executor(resolve) {
????console.log(2);
????for( var i=0 ; i<10000 ; i++ ) { i == 9999 && resolve(); }
????console.log(3);
}).then(function() {
????console.log(4);
});
console.log(5);