Promise 對象
概述
是異步編程的一種解決方案忠烛。
從語法上說权逗,Promise 是一個對象,從它可以獲取異步操作的消息师坎。
狀態(tài)
Promise 異步操作有三種狀態(tài):pending(進(jìn)行中)堪滨、fulfilled(已成功)和 rejected(已失敗)惶岭。除了異步操作的結(jié)果,任何其他操作都無法改變這個狀態(tài)按灶。
Promise 對象只有:從 pending 變?yōu)?fulfilled 和從 pending 變?yōu)?rejected 的狀態(tài)改變鸯旁。只要處于 fulfilled 和 rejected ,狀態(tài)就不會再變了即resolved(已定型)铺罢。
const p1 = new Promise(function(resolve,reject){
resolve('success1');
resolve('success2');
});
const p2 = new Promise(function(){
resolve('success3');
reject('reject');
});
p1.then(function(value){
console.log(value); // success1
});
p2.then(function(value){
console.log(value); // success3
});
狀態(tài)的缺點
1.無法取消 Promise 韭赘,一旦新建它就會立即執(zhí)行,無法中途取消泉瞻。
2.如果不設(shè)置回調(diào)函數(shù)袖牙,Promise 內(nèi)部拋出的錯誤,不會反應(yīng)到外部鞭达。
3.當(dāng)處于 pending 狀態(tài)時畴蹭,無法得知目前進(jìn)展到哪一個階段(剛剛開始還是即將完成)。
then方法
概述
then 方法接收兩個函數(shù)作為參數(shù)叨襟,第一個參數(shù)是 Promise 執(zhí)行成功時的回調(diào)芹啥,第二個參數(shù)是 Promise 執(zhí)行失敗時的回調(diào),兩個函數(shù)只會有一個被調(diào)用墓怀。
then方法的特點
在 Java 事件隊列的當(dāng)前運(yùn)行完成之前卫键,回調(diào)函數(shù)永遠(yuǎn)不會被調(diào)用。
const p = new Promise(function(resolve,reject){
resolve('success');
});
p.then(function(value){
console.log(value);
});
console.log('first');
//輸出結(jié)果
// first
// success
通過 .then形式添加的回調(diào)函數(shù)钓账,不論什么時候,都會被調(diào)用服协。
通過多次調(diào)用.then啦粹,可以添加多個回調(diào)函數(shù),它們會按照插入順序并且獨(dú)立運(yùn)行跳纳。
then 方法將返回一個 resolved 或 rejected 狀態(tài)的 Promise 對象用于鏈?zhǔn)秸{(diào)用贪嫂,且 Promise 對象的值就是這個返回值。
const p = new Promise(function(resolve,reject){
resolve(1);
}).then(function(value){ // 第一個then // 1
console.log(value);
return value * 2;
}).then(function(value){ // 第二個then // 2
console.log(value);
}).then(function(value){ // 第三個then // undefined
console.log(value);
return Promise.resolve('resolve');
}).then(function(value){ // 第四個then // resolve
console.log(value);
return Promise.reject('reject');
}).then(function(value){ // 第五個then //reject:reject
console.log('resolve:' + value);
}, function(err) {
console.log('reject:' + err);
});
需要注意的點
1.簡便的 Promise 鏈?zhǔn)骄幊套詈帽3直馄交诽粒灰短?Promise餐曹。
2.注意總是返回或終止 Promise 鏈。如下代碼所示朽合,創(chuàng)建新 Promise 但忘記返回它時饱狂,對應(yīng)鏈條被打破,導(dǎo)致 p4 會與 p2 和 p3 同時進(jìn)行讲婚。大多數(shù)瀏覽器中不能終止的 Promise 鏈里的 rejection俊柔,建議后面都跟上 .catch(error => console.log(error));
const p1 = new Promise(function(resolve,reject){
resolve(1);
}).then(function(result) {
p2(result).then(newResult => p3(newResult));
}).then(() => p4());