node.js Promise對(duì)象的使用方法實(shí)例分析
本文實(shí)例講述了node.js Promise對(duì)象的使用方法。分享給大家供大家參考,具體如下:
Promise對(duì)象是干嘛用的?
將異步操作以同步操作的流程表達(dá)出來
一、Promise對(duì)象的定義
let flag = true; const hello = new Promise(function (resolve, reject) { if (false) {//異步操作成功 resolve("success"); } else { reject("error"); } });
二、鏈?zhǔn)秸{(diào)用-then方法
使用then方法調(diào)用,第一個(gè)參數(shù)是成功回調(diào),第二個(gè)參數(shù)是失敗回調(diào),如下
hello.then( function (value) { console.log(value) }, function (err) { console.log(err) } );
下面我們分別定義三個(gè)方法,參數(shù)為延時(shí)執(zhí)行的秒數(shù)
- chenqionghe
- get
- muslce
function chenqionghe(second) { return new Promise((resolve, reject) => { setTimeout(function () { console.log("chenqionghe"); resolve(); }, second * 1000); }) } function get(second) { return new Promise((resolve, reject) => { setTimeout(function () { console.log("get"); resolve() }, second * 1000); }) } function muscle(second) { return new Promise((resolve, reject) => { setTimeout(function () { console.log("muscle"); resolve(); }, second * 1000); }) }
調(diào)用如下
chenqionghe(3) .then(function () { return get(2) }) .then(function () { return muscle(1) });
運(yùn)行輸出
chenqionghe
get
muscle
這樣就實(shí)現(xiàn)了鏈?zhǔn)降恼{(diào)用,相當(dāng)于同步的方式執(zhí)行了
如果不使用then調(diào)用,會(huì)發(fā)生什么情況?如下
chenqionghe(3); get(2); muscle(1);
結(jié)果如下
muscle
get
chenqionghe
我們看到chenqionghe雖然是第一個(gè)執(zhí)行,卻是最后輸出內(nèi)容,因?yàn)樵O(shè)置了3秒后執(zhí)行
重點(diǎn):
- Promise 對(duì)象的錯(cuò)誤具有“冒泡”性質(zhì),會(huì)一直向后傳遞,直到被捕獲為止。也就是說,錯(cuò)誤總是會(huì)被下一個(gè)catch語句捕獲。
- 一般來說,不要在then方法里面定義 Reject 狀態(tài)的回調(diào)函數(shù)(即then的第二個(gè)參數(shù)),總是使用catch方法。
三、捕獲異常-catch
chenqionghe(3) .then(function () { return get(2) }) .then(function () { throw new Error("abc"); return muscle(1) }) .catch(function (e) { console.log("異常:" + e.message) }) ;
輸出
chenqionghe
get
異常:abc
異常本質(zhì)也是一個(gè)Promise,所以后面還可以執(zhí)行then
chenqionghe(3) .then(function () { return get(2) }) .then(function () { throw new Error("abc"); return muscle(1) }) .catch(function (e) { console.log("異常:" + e.message) }) .then(function () { console.log("異常后執(zhí)行") }) ;
運(yùn)行輸出
chenqionghe
get
異常:abc
異常后執(zhí)行
四、收尾執(zhí)行-finally
就是不管怎么樣,都會(huì)執(zhí)行的方法,即使是拋異常了
chenqionghe(3) .then(function () { return get(2) }) .then(function () { throw new Error("abc"); return muscle(1) }) .catch(function (e) { console.log("異常:" + e.message) }) .finally(function () { console.log("最后都會(huì)執(zhí)行的方法") }) ;
執(zhí)行輸出
chenqionghe
get
異常:abc
最后都會(huì)執(zhí)行的方法
finally本質(zhì)上也是then方法的特例
五、其他方法
all
用于將多個(gè)promise實(shí)例包裝成一個(gè)新的promise實(shí)例
const p = Promise.all([p1, p2, p3]);
- 當(dāng)p1、p2、p3都執(zhí)行功能,會(huì)調(diào)用p的回調(diào)函數(shù),傳p1、p2、p3返回值的一個(gè)數(shù)組
- 當(dāng)p1、p2、p3其中有一個(gè)執(zhí)行reject,第一個(gè)執(zhí)行reject方法的返回值會(huì)傳遞給p的回調(diào)函數(shù)
race
類似all,也將多個(gè)promise實(shí)例包裝成一個(gè)新的promise實(shí)例
不同的是,要p1、p2、p3之中有一個(gè)實(shí)例發(fā)生改變,最先改變的 Promise 實(shí)例的返回值會(huì)傳遞給p的回調(diào)函數(shù)。
resolve
將現(xiàn)有對(duì)象轉(zhuǎn)為 Promise 對(duì)象
Promise.resolve('foo') // 等價(jià)于 new Promise(resolve => resolve('foo'))
reject
返回一個(gè)新的 Promise 實(shí)例,該實(shí)例的狀態(tài)為rejected
const p = Promise.reject('出錯(cuò)了'); // 等同于 const p = new Promise((resolve, reject) => reject('出錯(cuò)了'))
希望本文所述對(duì)大家node.js程序設(shè)計(jì)有所幫助。
相關(guān)文章
又拍云 Node.js 實(shí)現(xiàn)文件上傳、刪除功能
這篇文章主要介紹了又拍云 Node.js 實(shí)現(xiàn)文件上傳、刪除功能,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-10-10React和Node.js快速上傳進(jìn)度條功能實(shí)現(xiàn)
這篇文章主要為大家介紹了React和Node.js快速上傳進(jìn)度條功能實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03輕松創(chuàng)建nodejs服務(wù)器(4):路由
這篇文章主要介紹了輕松創(chuàng)建nodejs服務(wù)器(4):路由,服務(wù)器需要根據(jù)不同的URL或請(qǐng)求來執(zhí)行不一樣的操作,我們可以通過路由來實(shí)現(xiàn)這個(gè)步驟,需要的朋友可以參考下2014-12-12詳解nodejs中exports和module.exports的區(qū)別
本文主要介紹了exports 和 module.exports 的區(qū)別。具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-02-02Docker平臺(tái)下NodeJs?Puppeteer實(shí)現(xiàn)html轉(zhuǎn)pdf過程示例
這篇文章主要為大家介紹了Docker平臺(tái)下NodeJs?Puppeteer實(shí)現(xiàn)html轉(zhuǎn)pdf過程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12Nodejs環(huán)境Eggjs加簽驗(yàn)簽示例代碼
這篇文章主要介紹了Nodejs環(huán)境Eggjs加簽驗(yàn)簽示例代碼,文章開頭給大家介紹了加簽和驗(yàn)簽的基本概念,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07Node.js通過身份證號(hào)驗(yàn)證年齡、出生日期與性別方法示例
最近工作中需要對(duì)身份證號(hào)的年齡、出生日期與性別進(jìn)行驗(yàn)證,所以這篇文章主要介紹了Node.js通過身份證號(hào)驗(yàn)證年齡、出生日期與性別的方法,在介紹完node.js的實(shí)現(xiàn)方法后又給大家分類的利用JS實(shí)現(xiàn)的方法,需要的朋友可以參考下。2017-03-03