網站首頁 編程語言 正文
1.Promise是什么?
從用途上來說:
(1)promise主要用于異步計算。
(2)可以將異步操作隊列化,按照期望的順序執行,返回符合預期的結果。
(3)可以在對象之間傳遞和操作promise,幫助我們處理隊列。
從語法上說:
(1)Promise 是一個對象,從它可以獲取異步操作的消息。
(2)Promise 提供統一的 API,各種異步操作都可以用同樣的方法進行處理
2.Promise對象的特點?
對象的狀態不受外界影響。
Promise對象代表一個異步操作,有三種狀態:
- pending(進行中)
- fulfilled(已成功)
- rejected(已失敗)
只有異步操作的結果,可以決定當前是哪一種狀態,任何其他操作都無法改變這個狀態。
一旦狀態改變,就不會再變,任何時候都可以得到這個結果。
Promise對象的狀態變化只有如下2種:
- pending->fulfilled
- pending->rejected
只要這兩種情況發生,狀態就凝固,不會再變,會一直保持這個結果。
說明:如果改變已經發生了,你再對Promise對象添加回調函數,也會立即得到這個結果。這與事件(Event)完全不同,事件的特點是,如果你錯過了它,再去監聽,是得不到結果的。
3.Promise的缺點?
無法取消Promise,一旦新建它就會立即執行,無法中途取消。如果不設置回調函數,Promise內部拋出的錯誤,不會反應到外部。當處于pending狀態時,無法得知目前進展到哪一個階段(剛剛開始還是即將完成)
4.Promise的基本用法?
ES6 規定,Promise對象是一個構造函數,用來生成Promise實例。
const promise = new Promise(function(resolve, reject) {
// ... some code
if (/* 異步操作成功 */){
resolve(value); // 異步操作成功時調用,并將異步操作的結果作為參數傳遞出去
} else {
reject(error); // 異步操作失敗時調用,并將異步操作的結果作為參數傳遞出去
}
});
對promise對象穿出的值進行處理
promise.then(function(value) { // 這兩個函數都接受Promise對象傳出的值作為參數。
// success // 成功時,調用第一個函數
}, function(error) {
// failure // 失敗時,調用第二個函數
});
或者
promise.then(function(value) {
// success // 成功時,調用第一個函數
}).catch(function(error) {
// failure // 失敗時,調用第二個函數
});
說明:
(1) promise構造函數,接受一個函數作為參數。
(2) 這個函數又有兩個參數,接受 resolve 和 reject 這兩個參數。
(3) resolve 和 reject 也是函數
resolve 函數的作用:
將Promise對象的狀態從pending 變為 resolved,
在異步操作成功時調用,并將異步操作的結果,作為參數傳遞出去。!!!
reject 函數的作用:
將Promise對象的狀態從“從 pending 變為 rejected,
在異步操作失敗時調用,并將異步操作報出的錯誤,作為參數傳遞出去。!!!
5.Promise 新建后就會立即執行?
componentDidMount() {
let p = new Promise((resolve,reject) => {
console.log('1')
resolve();
})
p.then(result => {
console.log('2')
})
console.log('3')
}
// 執行結果:
// 1
// 3
// 2
說明:
上面代碼中,Promise 新建后立即執行,所以首先輸出的是 1 。
然后,then方法指定的回調函數,將在當前腳本所有同步任務執行完才會執行,所以 2 最后輸出。
例子code
componentDidMount() {
new Promise(function (resolve, reject) {
console.log('start new Promise...');
var timeOut = Math.random() * 2;
console.log('set timeout to: ' + timeOut + ' seconds.');
setTimeout(function () {
if (timeOut < 1) {
console.log('call resolve()...');
resolve('200 OK');
}
else {
console.log('call reject()...');
reject('timeout in ' + timeOut + ' seconds.');
}
}, timeOut * 1000);
}).then(function (result) { //這里的參數result就是resolve方法通過參數傳出的內容
console.log('Done: ' + result);
},function (result) { //這里的參數result就是reject方法通過參數傳出的內容
console.log('Failed: ' + result);
});
}
運行結果:
6.鏈式任務
Promise還可以做更多的事情,比如,有若干個異步任務,需要先做任務1,如果成功后再做任務2,任何任務失敗則不再繼續并執行錯誤處理函數。
要串行執行這樣的異步任務,不用Promise需要寫一層一層的嵌套代碼。有了Promise,我們只需要簡單地寫:
job1.then(job2).then(job3).catch(handleError);
例子code
componentDidMount() {
// 0.5秒后返回input*input的計算結果:
function multiply(input) {
return new Promise(function (resolve, reject) {
console.log('calculating ' + input + ' x ' + input + '...');
setTimeout(resolve, 500, input * input);
});
}
// 0.5秒后返回input+input的計算結果:
function add(input) {
return new Promise(function (resolve, reject) {
console.log('calculating ' + input + ' + ' + input + '...');
setTimeout(resolve, 500, input + input);
});
}
var p = new Promise(function (resolve, reject) {
console.log('start new Promise...');
resolve(123);
});
p.then(multiply)
.then(add)
.then(multiply)
.then(add)
.then(function (result) {
console.log('Got value: ' + result);
});
}
運行結果:
總結
原文鏈接:https://blog.csdn.net/u013514928/article/details/89737024
相關推薦
- 2022-07-04 C#中File靜態類對文件的讀取寫入_C#教程
- 2023-01-13 python中的txt文件轉換為XML_python
- 2023-03-16 Android虛擬機Dalvik和ART科普_Android
- 2022-09-14 python重寫方法和重寫特殊構造方法_python
- 2022-06-27 Python深拷貝與淺拷貝引用_python
- 2022-06-19 Go中Writer和Reader接口的使用入門_Golang
- 2023-11-26 (有效解決)Android Studio 運行項目時報 Package install error:
- 2022-12-10 C++模擬實現string的方法詳解_C 語言
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支