欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

node.js Promise對(duì)象的使用方法實(shí)例分析

 更新時(shí)間:2019年12月26日 11:54:26   作者:雪山飛豬  
這篇文章主要介紹了node.js Promise對(duì)象的使用方法,結(jié)合實(shí)例形式分析了node.js中Promise對(duì)象的功能、定義、調(diào)用方法及相關(guān)使用技巧,需要的朋友可以參考下

本文實(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ù)

  1. chenqionghe
  2. get
  3. 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):

  1. Promise 對(duì)象的錯(cuò)誤具有“冒泡”性質(zhì),會(huì)一直向后傳遞,直到被捕獲為止。也就是說,錯(cuò)誤總是會(huì)被下一個(gè)catch語句捕獲。
  2. 一般來說,不要在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]);
  1. 當(dāng)p1、p2、p3都執(zhí)行功能,會(huì)調(diào)用p的回調(diào)函數(shù),傳p1、p2、p3返回值的一個(gè)數(shù)組
  2. 當(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)文件上傳、刪除功能

    這篇文章主要介紹了又拍云 Node.js 實(shí)現(xiàn)文件上傳、刪除功能,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-10-10
  • React和Node.js快速上傳進(jìn)度條功能實(shí)現(xiàn)

    React和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):路由

    這篇文章主要介紹了輕松創(chuàng)建nodejs服務(wù)器(4):路由,服務(wù)器需要根據(jù)不同的URL或請(qǐng)求來執(zhí)行不一樣的操作,我們可以通過路由來實(shí)現(xiàn)這個(gè)步驟,需要的朋友可以參考下
    2014-12-12
  • nodejs如何獲取時(shí)間戳與時(shí)間差

    nodejs如何獲取時(shí)間戳與時(shí)間差

    本文詳細(xì)介紹了nodejs獲取時(shí)間戳與時(shí)間差的多種方法,對(duì)平時(shí)nodejs的使用很有幫助,下面一起來看看吧。
    2016-08-08
  • 詳解nodejs中exports和module.exports的區(qū)別

    詳解nodejs中exports和module.exports的區(qū)別

    本文主要介紹了exports 和 module.exports 的區(qū)別。具有很好的參考價(jià)值,下面跟著小編一起來看下吧
    2017-02-02
  • Docker平臺(tái)下NodeJs?Puppeteer實(shí)現(xiàn)html轉(zhuǎn)pdf過程示例

    Docker平臺(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-12
  • Nodejs環(huán)境Eggjs加簽驗(yàn)簽示例代碼

    Nodejs環(huán)境Eggjs加簽驗(yàn)簽示例代碼

    這篇文章主要介紹了Nodejs環(huán)境Eggjs加簽驗(yàn)簽示例代碼,文章開頭給大家介紹了加簽和驗(yàn)簽的基本概念,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • Node.js通過身份證號(hào)驗(yàn)證年齡、出生日期與性別方法示例

    Node.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
  • Node.js制作簡(jiǎn)單聊天室

    Node.js制作簡(jiǎn)單聊天室

    這篇文章主要為大家詳細(xì)介紹了Node.js制作簡(jiǎn)單聊天室的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • Express之托管靜態(tài)文件的方法

    Express之托管靜態(tài)文件的方法

    本篇文章主要介紹了Express之托管靜態(tài)文件的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06

最新評(píng)論