精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

把 Node.js 中的回調轉換為 Promise

開發 前端
在本文中,我們將討論如何將 JavaScript 回調轉換為 Promise。ES6 的知識將會派上用場,因為我們將會使用 展開操作符之類的功能來簡化要做的事情。

介紹

在幾年前,回調是 JavaScript 中實現執行異步代碼的唯一方法。回調本身幾乎沒有什么問題,最值得注意的是“回調地獄”。

在 ES6 中引入了 Promise 作為這些問題的解決方案。最后通過引入 async/await 關鍵字來提供更好的體驗并提高了可讀性。

即使有了新的方法,但是仍然有許多使用回調的原生模塊和庫。在本文中,我們將討論如何將 JavaScript 回調轉換為 Promise。ES6 的知識將會派上用場,因為我們將會使用 展開操作符之類的功能來簡化要做的事情。

什么是回調

回調是一個函數參數,恰好是一個函數本身。雖然我們可以創建任何函數來接受另一個函數,但回調主要用于異步操作。

JavaScript 是一種解釋性語言,一次只能處理一行代碼。有些任務可能需要很長時間才能完成,例如下載或讀取大文件等。JavaScript 將這些運行時間很長的任務轉移到瀏覽器或 Node.js 環境中的其他進程中。這樣它就不會阻止其他代碼的執行。

通常異步函數會接受回調函數,所以完成之后可以處理其數據。

舉個例子,我們將編寫一個回調函數,這個函數會在程序成功從硬盤讀取文件之后執行。

所以需要準備一個名為 sample.txt 的文本文件,其中包含以下內容:

  1. Hello world from sample.txt 

然后寫一個簡單的 Node.js 腳本來讀取文件:

  1. const fs = require('fs'); 
  2.  
  3. fs.readFile('./sample.txt', 'utf-8', (err, data) => { 
  4.     if (err) { 
  5.         // 處理錯誤 
  6.         console.error(err); 
  7.           return; 
  8.     } 
  9.     console.log(data); 
  10. }); 
  11.  
  12. for (let i = 0; i < 10; i++) { 
  13.     console.log(i); 

運行代碼后將會輸出:

  1. ... 
  2. Hello world from sample.txt 

如果這段代碼,應該在執行回調之前看到 0..9 被輸出到控制臺。這是因為 JavaScript 的異步管理機制。在讀取文件完畢之后,輸出文件內容的回調才被調用。

順便說明一下,回調也可以在同步方法中使用。例如 Array.sort() 會接受一個回調函數,這個函數允許你自定義元素的排序方式。

接受回調的函數被稱為“高階函數”。

現在我們有了一個更好的回調方法。那么們繼續看看什么是 Promise。

什么是 Promise

在 ECMAScript 2015(ES6)中引入了 Promise,用來改善在異步編程方面的體驗。顧名思義,JavaScript 對象最終將返回的“值”或“錯誤”應該是一個 Promise。

一個 Promise 有 3 個狀態:

  • Pending(待處理):用來指示異步操作尚未完成的初始狀態。
  • Fulfilled(已完成):表示異步操作已成功完成。
  • Rejected(拒絕):表示異步操作失敗。

大多數 Promise 最終看起來像這樣:

  1. someAsynchronousFunction() 
  2.     .then(data => { 
  3.         // promise 被完成 
  4.         console.log(data); 
  5.     }) 
  6.     .catch(err => { 
  7.         // promise 被拒絕 
  8.         console.error(err); 
  9.     }); 

Promise 在現代 JavaScript 中非常重要,因為它們與 ECMAScript 2016 中引入的 async/await 關鍵字一起使用。使用 async / await 就不需要再用回調或 then() 和 catch() 來編寫異步代碼。

如果要改寫前面的例子,應該是這樣:

  1. try { 
  2.     const data = await someAsynchronousFunction(); 
  3. } catch(err) { 
  4.     // promise 被拒絕 
  5.     console.error(err); 

這看起來很像“一般的”同步 JavaScript。大多數流行的JavaScript庫和新項目都把 Promises 與 async/await 關鍵字放在一起用。

但是,如果你要更新現有的庫或遇到舊的代碼,則可能會對將基于回調的 API 遷移到基于 Promise 的 API 感興趣,這樣可以改善你的開發體驗。

來看一下將回調轉換為 Promise 的幾種方法。

將回調轉換為 Promise

Node.js Promise

大多數在 Node.js 中接受回調的異步函數(例如 fs 模塊)有標準的實現方式:把回調作為最后一個參數傳遞。

例如這是在不指定文本編碼的情況下用 fs.readFile() 讀取文件的方法:

  1. fs.readFile('./sample.txt', (err, data) => { 
  2.     if (err) { 
  3.         console.error(err); 
  4.           return; 
  5.     } 
  6.     console.log(data); 
  7. }); 

注意:如果你指定 utf-8 作為編碼,那么得到的輸出是一個字符串。如果不指定得到的輸出是 Buffer。

另外傳給這個函數的回調應接受 Error,因為它是第一個參數。之后可以有任意數量的輸出。

如果你需要轉換為 Promise 的函數遵循這些規則,那么可以用 util.promisify ,這是一個原生 Node.js 模塊,其中包含對 Promise 的回調。

首先導入ʻutil`模塊:

  1. const util = require('util'); 

然后用 promisify 方法將其轉換為 Promise:

  1. const fs = require('fs'); 
  2. const readFile = util.promisify(fs.readFile); 

現在,把新創建的函數用作 promise:

  1. readFile('./sample.txt', 'utf-8') 
  2.     .then(data => { 
  3.         console.log(data); 
  4.     }) 
  5.     .catch(err => { 
  6.         console.log(err); 
  7.     }); 

另外也可以用下面這個示例中給出的 async/await 關鍵字:

  1. const fs = require('fs'); 
  2. const util = require('util'); 
  3.  
  4. const readFile = util.promisify(fs.readFile); 
  5.  
  6. (async () => { 
  7.     try { 
  8.         const content = await readFile('./sample.txt', 'utf-8'); 
  9.         console.log(content); 
  10.     } catch (err) { 
  11.         console.error(err); 
  12.     } 
  13. })(); 

你只能在用 async 創建的函數中使用 await 關鍵字,這也是為什么要使用函數包裝器的原因。函數包裝器也被稱為立即調用的函數表達式。

如果你的回調不遵循這個特定標準也不用擔心。util.promisify() 函數可讓你自定義轉換是如何發生的。

注意:Promise 在被引入后不久就開始流行了。Node.js 已經將大部分核心函數從回調轉換成了基于 Promise 的API。

如果需要用 Promise 處理文件,可以用 Node.js 附帶的庫(https://nodejs.org/docs/latest-v10.x/api/fs.html#fs_fs_promises_api)。

現在你已經了解了如何將 Node.js 標準樣式回調隱含到 Promise 中。從 Node.js 8 開始,這個模塊僅在 Node.js 上可用。如果你用的是瀏覽器或早期版本版本的 Node,則最好創建自己的基于 Promise 的函數版本。

2. 創建你自己的 Promise

讓我們討論一下怎樣把回調轉為 util.promisify() 函數的 promise。

思路是創建一個新的包含回調函數的 Promise 對象。如果回調函數返回錯誤,就拒絕帶有該錯誤的Promise。如果回調函數返回非錯誤輸出,就解決并輸出 Promise。

先把回調轉換為一個接受固定參數的函數的 promise 開始:

  1. const fs = require('fs'); 
  2.  
  3. const readFile = (fileName, encoding) => { 
  4.     return new Promise((resolve, reject) => { 
  5.         fs.readFile(fileName, encoding, (err, data) => { 
  6.             if (err) { 
  7.                 return reject(err); 
  8.             } 
  9.  
  10.             resolve(data); 
  11.         }); 
  12.     }); 
  13.  
  14. readFile('./sample.txt') 
  15.     .then(data => { 
  16.         console.log(data); 
  17.     }) 
  18.     .catch(err => { 
  19.         console.log(err); 
  20.     }); 

新函數 readFile() 接受了用來讀取 fs.readFile() 文件的兩個參數。然后創建一個新的 Promise 對象,該對象包裝了該函數,并接受回調,在本例中為 fs.readFile()。

要 reject Promise 而不是返回錯誤。所以代碼中沒有立即把數據輸出,而是先 resolve 了Promise。然后像以前一樣使用基于 Promise 的 readFile() 函數。

接下來看看接受動態數量參數的函數:

  1. const getMaxCustom = (callback, ...args) => { 
  2.     let max = -Infinity; 
  3.  
  4.     for (let i of args) { 
  5.         if (i > max) { 
  6.             max = i
  7.         } 
  8.     } 
  9.  
  10.     callback(max); 
  11.  
  12. getMaxCustom((max) => { console.log('Max is ' + max) }, 10, 2, 23, 1, 111, 20); 

第一個參數是 callback 參數,這使它在接受回調的函數中有點與眾不同。

轉換為 promise 的方式和上一個例子一樣。創建一個新的 Promise 對象,這個對象包裝使用回調的函數。如果遇到錯誤,就 reject,當結果出現時將會 resolve。

我們的 promise 版本如下:

  1. const getMaxPromise = (...args) => { 
  2.     return new Promise((resolve) => { 
  3.         getMaxCustom((max) => { 
  4.             resolve(max); 
  5.         }, ...args); 
  6.     }); 
  7.  
  8. getMaxCustom(10, 2, 23, 1, 111, 20) 
  9.     .then(max => console.log(max)); 

在創建 promise 時,不管函數是以非標準方式還是帶有許多參數使用回調都無關緊要。我們可以完全控制它的完成方式,并且原理是一樣的。

總結

盡管現在回調已成為 JavaScript 中利用異步代碼的默認方法,但 Promise 是一種更現代的方法,它更容易使用。如果遇到了使用回調的代碼庫,那么現在就可以把它轉換為 Promise。

在本文中,我們首先學到了如何 在Node.js 中使用 utils.promisfy() 方法將接受回調的函數轉換為 Promise。然后,了解了如何創建自己的 Promise 對象,并在對象中包裝了無需使用外部庫即可接受回調的函數。這樣許多舊 JavaScript 代碼可以輕松地與現代的代碼庫和混合在一起。

 

責任編輯:趙寧寧 來源: 前端先鋒
相關推薦

2022-10-12 08:00:00

語音識別Node.js音頻質量

2025-07-11 08:09:07

Node.jsAPI權限

2022-06-04 07:21:19

requireJSNode.js

2024-01-05 08:49:15

Node.js異步編程

2020-04-15 15:48:03

Node.jsstream前端

2016-08-11 14:02:02

NodeJS前端

2021-05-21 09:36:42

開發技能代碼

2013-11-01 09:34:56

Node.js技術

2015-03-10 10:59:18

Node.js開發指南基礎介紹

2017-03-20 13:43:51

Node.js內存泄漏

2017-03-19 16:40:28

漏洞Node.js內存泄漏

2013-12-13 09:42:30

Node.js技術

2021-12-25 22:29:57

Node.js 微任務處理事件循環

2012-02-03 09:25:39

Node.js

2020-05-29 15:33:28

Node.js框架JavaScript

2011-09-08 14:16:12

Node.js

2021-12-01 00:05:03

Js應用Ebpf

2020-01-03 16:04:10

Node.js內存泄漏

2011-09-08 13:53:31

Node.js

2021-03-04 23:12:57

Node.js異步迭代器開發
點贊
收藏

51CTO技術棧公眾號

999久久欧美人妻一区二区| 国产欧美 在线欧美| 亚洲成a人片在线www| 最新国产在线拍揄自揄视频| 粉嫩av一区二区三区在线播放 | 自拍偷拍精品视频| 爽成人777777婷婷| 精品999久久久| 久久久久人妻精品一区三寸| 日本电影全部在线观看网站视频| 国产成人精品三级| 91sao在线观看国产| 一级片黄色录像| 麻豆国产一区| 91福利精品第一导航| 青春草在线视频免费观看| 国产成人无码www免费视频播放| 在线视频亚洲| www.精品av.com| 中文在线永久免费观看| 欧美日韩卡一| 午夜日韩在线观看| 综合操久久久| 婷婷国产在线| 国产精品一区免费在线观看| 国产成人精品999| 国产大片免费看| 美女毛片一区二区三区四区最新中文字幕亚洲 | 精品一区久久久| 亚洲一级视频在线观看| 最新国产乱人伦偷精品免费网站| 一级做a爰片久久毛片美女图片| 久久人妻少妇嫩草av蜜桃| 三级成人在线| 亚洲成人动漫在线观看| 亚洲国产精品女人| 福利在线视频导航| 91在线观看一区二区| 亚洲最大av网站| 中文字幕一区二区久久人妻| 亚洲一区不卡| 欧美黄色免费网站| caoporn91| 日韩欧美大片| 亚洲天堂色网站| 成人在线视频免费播放| 精品国产一区二区三区性色av| 在线免费观看成人短视频| 午夜视频一区在线观看| 日韩一区二区免费视频| 一道本视频在线观看| 在线观看网站免费入口在线观看国内 | 99久久伊人精品| 97人人澡人人爽| 国产又粗又猛视频| 蜜桃91丨九色丨蝌蚪91桃色| 日本免费在线精品| 特黄视频免费看| 在线午夜精品| 性欧美在线看片a免费观看| 国产黄色片在线免费观看| 亚洲a在线视频| 日韩在线免费视频| 精品一区二区在线观看视频| 色狮一区二区三区四区视频| 最近中文字幕2019免费| 午夜黄色福利视频| 国产精品99一区二区三| 久久精品国产电影| 一级片一级片一级片| 午夜av一区| 毛片精品免费在线观看| 青青操国产视频| 欧美精品一卡| 国a精品视频大全| 国产做受高潮漫动| 亚洲自啪免费| 国产精品免费在线免费| 亚洲一区二区人妻| 国产精品综合在线视频| 翡翠波斯猫1977年美国| 天天操天天射天天| 久久综合九色综合97_久久久| 免费电影一区| www.亚洲.com| 亚洲欧美日韩综合aⅴ视频| 久久精品无码中文字幕| 亚洲一二三四| 欧美日韩国产小视频在线观看| 爱豆国产剧免费观看大全剧苏畅| 欧美黄视频在线观看| 亚洲第一av网| 久久久久久久久久久久| 欧美电影免费播放| 欧美高清视频在线观看| 日日夜夜操视频| 久久99久久99精品免视看婷婷| 亚洲aa在线观看| 特级丰满少妇一级aaaa爱毛片| 久久精品视频一区二区三区| 一区二区三区四区欧美日韩| 波多野结衣中文字幕久久| 色综合婷婷久久| 天堂在线一区二区三区| 欧美福利在线播放网址导航| 中文字幕亚洲无线码a| 精品爆乳一区二区三区无码av| 亚洲毛片在线| 国产欧美精品一区二区| 天天干天天爽天天操| 国产精品色噜噜| 国产欧美精品aaaaaa片| 色豆豆成人网| 精品国产91久久久久久久妲己| 99久久久无码国产精品性| 一区二区三区在线| 国产999精品久久久| 亚洲av色香蕉一区二区三区| 久久看人人爽人人| 免费极品av一视觉盛宴| 国产精品毛片久久久久久久久久99999999| 日韩免费一区二区| 老司机福利在线观看| 亚洲一卡久久| 成人av男人的天堂| 日韩毛片久久久| 欧美性猛交xxxx黑人猛交| 特种兵之深入敌后| 久久国产精品亚洲人一区二区三区 | 国产一区二区av在线| 亚洲人成网站在线播| 国产在线欧美在线| 国内精品写真在线观看| 三区精品视频观看| 手机在线观看av网站| 日韩精品最新网址| 亚洲少妇xxx| 日韩精品一级二级| 久久精品国产第一区二区三区最新章节 | 久久99九九| 日本不卡影院| 9191国产精品| 制服丨自拍丨欧美丨动漫丨| 日韩国产在线一| 美女被啪啪一区二区| а_天堂中文在线| 日韩欧美自拍偷拍| 国产十六处破外女视频| 精品一区二区三区在线播放| 视频一区免费观看| 国产成人午夜性a一级毛片| 精品香蕉一区二区三区| 西西44rtwww国产精品| av激情综合网| 性欧美大战久久久久久久| 91成人福利| 久久久久久999| 午夜精品久久久久久久99热黄桃| 亚洲女人****多毛耸耸8| 五月激情婷婷在线| 欧美成人精品一区二区三区在线看| 国产精品白嫩初高中害羞小美女| 可以在线观看的av| 欧美影院午夜播放| 人人爽人人爽人人片| 免费成人美女在线观看| 一区国产精品| 国产不卡精品| 萌白酱国产一区二区| 不卡视频在线播放| 亚洲国产精品尤物yw在线观看| 高清中文字幕mv的电影| 99国内精品| 欧美日韩在线观看一区| 日韩一级二级| 精品久久久999| 精品人妻一区二区三区三区四区| 亚洲午夜影视影院在线观看| 艳妇乳肉豪妇荡乳xxx| 国产欧美日韩一级| 日本一区二区精品| 成人在线分类| 久久久久久久成人| 免费在线视频一级不卡| 欧美日韩免费观看一区三区| www深夜成人a√在线| 成人激情小说网站| 成熟老妇女视频| 婷婷综合久久| 国产91免费视频| 午夜欧美巨大性欧美巨大| 日韩中文字幕在线播放| 性做久久久久久久久久| 一本久久综合亚洲鲁鲁五月天 | 国产宾馆实践打屁股91| 免费看的黄色大片| 清纯唯美综合亚洲| 97视频中文字幕| 日韩免费va| 欧美床上激情在线观看| 手机福利小视频在线播放| 欧美系列亚洲系列| 久热精品在线观看| 中文字幕av一区二区三区免费看| 69久久精品无码一区二区| 亚洲免费高清| 国产精品美女在线播放| 香蕉久久夜色精品国产更新时间| 国产精品入口尤物| 成人bbav| 久久婷婷国产麻豆91天堂| 天天躁日日躁狠狠躁喷水| 欧美日韩亚洲综合一区二区三区 | 亚洲大片在线观看| 欧美午夜激情影院| 成人18视频日本| 日本高清久久久| 欧美综合国产| 免费极品av一视觉盛宴| 色777狠狠狠综合伊人| 黄色99视频| 久久免费福利| 国产精品久久久久久网站| √8天堂资源地址中文在线| 视频在线观看99| 免费a级毛片在线观看| 欧美mv日韩mv国产网站| 一卡二卡三卡在线| 一本大道综合伊人精品热热| www.av视频在线观看| 自拍偷拍亚洲综合| 欧美一区二区三区粗大| 99精品黄色片免费大全| 岛国大片在线免费观看| 久久精品国产精品亚洲红杏| 成年人小视频网站| 日韩视频二区| www.国产在线视频| 在线看片不卡| 一本一道久久久a久久久精品91| 九一亚洲精品| 久久精品中文字幕一区二区三区| eeuss鲁片一区二区三区| 91精品视频在线看| 91成人小视频| 国产精品中文字幕在线观看| 国产经典一区| 日本欧美在线视频| 亚洲v.com| 97成人在线视频| 丰满的护士2在线观看高清| 蜜臀久久99精品久久久无需会员 | 午夜免费电影一区在线观看| 少妇精品久久久一区二区| 欧美日韩亚洲一区二区三区在线观看 | 国产精品女上位| 日韩一区二区a片免费观看| 久久综合色天天久久综合图片| 熟女丰满老熟女熟妇| 99精品视频一区二区| 毛茸茸多毛bbb毛多视频| eeuss影院一区二区三区| 在线免费观看a级片| 91色婷婷久久久久合中文| 国产精品嫩草av| 99久久婷婷国产| 国产艳俗歌舞表演hd| 久久久不卡网国产精品一区| 这里只有久久精品| 欧美国产国产综合| 婷婷社区五月天| 亚洲欧美电影院| 国产精品30p| 欧美日韩午夜视频在线观看| 波多野结衣激情视频| 欧美日韩美女一区二区| 一本一道精品欧美中文字幕| 制服丝袜激情欧洲亚洲| 亚洲产国偷v产偷v自拍涩爱| 亚洲成色999久久网站| 美国成人毛片| 色妞在线综合亚洲欧美| caoporn97在线视频| 性欧美xxxx| 成人黄色图片网站| 亚洲一区二区三区视频| 色婷婷久久久| 天天综合色天天综合色hd| 亚洲精品tv久久久久久久久久| 国产女教师bbwbbwbbw| 香蕉久久国产| 极品粉嫩美女露脸啪啪| 成人网男人的天堂| av黄色在线免费观看| 亚洲三级小视频| 日韩精品在线不卡| 欧美日韩一级二级三级| 免费观看黄一级视频| 国产一区二区三区网站| 污污影院在线观看| 国产精品第3页| 2020最新国产精品| 日韩一区不卡| 国内自拍视频一区二区三区| 日韩 欧美 高清| 国产一区二区精品久久| 黄色a一级视频| 1024亚洲合集| 欧美a∨亚洲欧美亚洲| 欧美丰满少妇xxxxx高潮对白 | 亚洲 欧美 国产 另类| 亚洲成人福利片| 亚洲中文字幕一区二区| 日韩大片免费观看视频播放| 麻豆视频在线播放| 国产成人黄色av| 成人18夜夜网深夜福利网| 一区二区三区四区免费视频| 老鸭窝91久久精品色噜噜导演| 99精品视频免费版的特色功能| 国产欧美中文在线| 欧美日韩精品区| 日韩欧美国产麻豆| 91社区在线观看播放| 日韩av电影免费观看高清| 我要色综合中文字幕| 亚洲一卡二卡| 久久成人一区| 中文字幕第六页| 国产精品久久网站| 色一情一乱一伦| 亚洲第一网中文字幕| 日本性爱视频在线观看| 成人a级免费视频| 精品久久久久中文字幕小说 | 免费av毛片在线看| 国产精品久久久久久久久久久久久久| 精品欠久久久中文字幕加勒比| 男同互操gay射视频在线看| 久久精品国产久精国产| 色婷婷国产精品免| 91精品福利在线| 免费av在线电影| 日本亚洲欧美三级| 伊人久久大香线蕉综合网蜜芽| 日本a在线免费观看| 国产电影一区二区三区| 欧美日韩一级大片| 欧美一级免费观看| gogogogo高清视频在线| 国产中文字幕亚洲| 久久精品国产99久久| 香蕉视频禁止18| 国产欧美日产一区| 糖心vlog精品一区二区| 一区二区三区国产视频| 日韩精品免费观看视频| 亚洲欧洲精品一区二区| 久久99久久99小草精品免视看| 欧美一区二区三区观看| 91精品国产色综合久久ai换脸| 老司机av在线免费看| 91精品久久久久久久久久久| 天天精品视频| 北条麻妃亚洲一区| 亚洲在线视频网站| 黄色美女一级片| 国语自产在线不卡| 亚洲激情77| 国产又粗又长又大的视频| 欧美国产乱子伦| 中文字幕永久免费视频| 精品久久久91| av不卡一区| 国产亚洲精品网站| 国产欧美一区二区精品忘忧草| 亚洲手机在线观看| 欧美另类在线观看| 日韩极品少妇| 国产免费999| ...xxx性欧美| 黄色小视频免费观看| 日本中文字幕久久看| 四虎成人av| 在线观看免费视频国产| 色综合欧美在线视频区| 黄av在线免费观看| 国产日韩一区二区| 日日嗨av一区二区三区四区| 欧美一级片在线视频| 亚洲第一区第二区| av激情成人网| 中文字幕乱码免费| 久久综合久久99| 99re只有精品| 欧美一区二区三区图| 欧美hentaied在线观看| 无码人妻精品一区二区三| 在线视频中文字幕一区二区| 日本在线观看高清完整版|