學(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í)際例子中呢平夜?
實(shí)戰(zhàn)應(yīng)用
需求,當(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í)行其他操作鸯檬。
// 方法
let 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í)例
經(jīng)典面試題:抄襲自不知名網(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);