中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ES6的Promise如何使用

發布時間:2022-02-19 09:15:28 來源:億速云 閱讀:123 作者:iii 欄目:開發技術

本篇內容介紹了“ES6的Promise如何使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

所謂Promise,簡單說就是一個容器,里面保存著某個未來才會結束的事件(通常是一個異步操作)的結果。ES6 規定,Promise對象是一個構造函數,用來生成Promise實例。

ES6的Promise如何使用

概述

是異步編程的一種解決方案。

從語法上說,Promise 是一個對象,從它可以獲取異步操作的消息。

Promise 狀態

狀態的特點

Promise 異步操作有三種狀態:pending(進行中)、fulfilled(已成功)和 rejected(已失敗)。除了異步操作的結果,任何其他操作都無法改變這個狀態。

Promise 對象只有:從 pending 變為 fulfilled 和從 pending 變為 rejected 的狀態改變。只要處于 fulfilled 和 rejected ,狀態就不會再變了即 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
});
狀態的缺點

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

如果不設置回調函數,Promise 內部拋出的錯誤,不會反應到外部。

當處于 pending 狀態時,無法得知目前進展到哪一個階段(剛剛開始還是即將完成)。

then 方法

then 方法接收兩個函數作為參數,第一個參數是 Promise 執行成功時的回調,第二個參數是 Promise 執行失敗時的回調,兩個函數只會有一個被調用。

then 方法的特點

在 JavaScript 事件隊列的當前運行完成之前,回調函數永遠不會被調用。

const p = new Promise(function(resolve,reject){
 resolve('success');
});

p.then(function(value){
 console.log(value);
});

console.log('first');
// first
// success

通過 .then 形式添加的回調函數,不論什么時候,都會被調用。

通過多次調用

.then

,可以添加多個回調函數,它們會按照插入順序并且獨立運行。

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 狀態的 Promise 對象用于鏈式調用,且 Promise 對象的值就是這個返回值。

then 方法注意點

簡便的 Promise 鏈式編程最好保持扁平化,不要嵌套 Promise。

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

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

創建新 Promise 但忘記返回它時,對應鏈條被打破,導致 p4 會與 p2 和 p3 同時進行。

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

“ES6的Promise如何使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

喀喇沁旗| 阿巴嘎旗| 灵寿县| 昌宁县| 甘肃省| 鹤岗市| 垦利县| 灯塔市| 永善县| 南陵县| 陇西县| 益阳市| 阿尔山市| 郑州市| 屯门区| 兴化市| 时尚| 扎鲁特旗| 东乡县| 泸溪县| 通山县| 大姚县| 华阴市| 凤庆县| 湘西| 雷波县| 托克逊县| 黔西| 临武县| 广元市| 肥西县| 香河县| 贵德县| 沁阳市| 呼伦贝尔市| 西贡区| 安仁县| 云林县| 光山县| 思南县| 唐山市|