日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
講解一下ES6Promise對象的使用方法

所謂Promise,簡單說就是一個容器,里面保存著某個未來才會結(jié)束的事件(通常是一個異步操作)的結(jié)果。

周寧網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)公司!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項目制作,到程序開發(fā),運營維護(hù)。創(chuàng)新互聯(lián)公司自2013年創(chuàng)立以來到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)公司

ES6 規(guī)定,Promise對象是一個構(gòu)造函數(shù),用來生成Promise實例。

Promise 狀態(tài)

狀態(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,reject){  
   resolve('success3');
   reject('reject');
});
p1.then(function(value){  
   console.log(value); // success1
});
p2.then(function(value){
   console.log(value); // success3
});

狀態(tài)的缺點

無法取消 Promise ,一旦新建它就會立即執(zhí)行,無法中途取消。

如果不設(shè)置回調(diào)函數(shù),Promise 內(nèi)部拋出的錯誤,不會反應(yīng)到外部。

當(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 方法的特點

在 JavaScript 事件隊列的當(dāng)前運行完成之前,回調(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');
// first
// success

通過 .then 形式添加的回調(diào)函數(shù),不論什么時候,都會被調(diào)用。

通過多次調(diào)用

.then

,可以添加多個回調(diào)函數(shù),它們會按照插入順序并且獨立運行。

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);
});

then 方法將返回一個 resolved 或 rejected 狀態(tài)的 Promise 對象用于鏈?zhǔn)秸{(diào)用,且 Promise 對象的值就是這個返回值。

then 方法注意點

簡便的 Promise 鏈?zhǔn)骄幊套詈帽3直馄交?,不要嵌?Promise。

注意總是返回或終止 Promise 鏈。

const p1 = new Promise(function(resolve,reject){
 resolve(1);
}).then(function(result) {
 p2(result).then(newResult => p3(newResult));
}).then(() => p4());

創(chuàng)建新 Promise 但忘記返回它時,對應(yīng)鏈條被打破,導(dǎo)致 p4 會與 p2 和 p3 同時進(jìn)行。

大多數(shù)瀏覽器中不能終止的 Promise 鏈里的 rejection,建議后面都跟上 .catch(error => console.log(error));


本文名稱:講解一下ES6Promise對象的使用方法
當(dāng)前網(wǎng)址:http://www.5511xx.com/article/cdecddg.html