返回顶部
首页 > 资讯 > 前端开发 > html >Node.js中怎么将回调转换为 Promise
  • 192
分享到

Node.js中怎么将回调转换为 Promise

2024-04-02 19:04:59 192人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关node.js中怎么将回调转换为 Promise,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。什么是回调回调是一个函数参数,恰好

这篇文章将为大家详细讲解有关node.js中怎么将回调转换为 Promise,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

什么是回调

回调是一个函数参数,恰好是一个函数本身。虽然我们可以创建任何函数来接受另一个函数,但回调主要用于异步操作。

javascript 是一种解释性语言,一次只能处理一行代码。有些任务可能需要很长时间才能完成,例如下载或读取大文件等。JavaScript  将这些运行时间很长的任务转移到浏览器或 node.js 环境中的其他进程中。这样它就不会阻止其他代码的执行。

通常异步函数会接受回调函数,所以完成之后可以处理其数据。

举个例子,我们将编写一个回调函数,这个函数会在程序成功从硬盘读取文件之后执行。

所以需要准备一个名为 sample.txt 的文本文件,其中包含以下内容:

Hello world from sample.txt

然后写一个简单的 Node.js 脚本来读取文件:

const fs = require('fs');  fs.readFile('./sample.txt', 'utf-8', (err, data) => {     if (err) {         // 处理错误         console.error(err);           return;     }     console.log(data); });  for (let i = 0; i < 10; i++) {     console.log(i); }

运行代码后将会输出:

0 ... 8 9 Hello world from sample.txt

如果这段代码,应该在执行回调之前看到 0..9 被输出到控制台。这是因为 JavaScript  的异步管理机制。在读取文件完毕之后,输出文件内容的回调才被调用。

顺便说明一下,回调也可以在同步方法中使用。例如 Array.sort() 会接受一个回调函数,这个函数允许你自定义元素的排序方式。

接受回调的函数被称为“高阶函数”。

现在我们有了一个更好的回调方法。那么们继续看看什么是 Promise。

什么是 Promise

在 ECMAScript 2015(es6)中引入了 Promise,用来改善在异步编程方面的体验。顾名思义,JavaScript  对象最终将返回的“值”或“错误”应该是一个 Promise。

一个 Promise 有 3 个状态:

  • Pending(待处理):用来指示异步操作尚未完成的初始状态。

  • Fulfilled(已完成):表示异步操作已成功完成。

  • Rejected(拒绝):表示异步操作失败。

大多数 Promise 最终看起来像这样:

someAsynchronousFunction()     .then(data => {         // promise 被完成         console.log(data);     })     .catch(err => {         // promise 被拒绝         console.error(err);     });

Promise 在现代 JavaScript 中非常重要,因为它们与 ECMAScript 2016 中引入的 async/await  关键字一起使用。使用 async / await 就不需要再用回调或 then() 和 catch() 来编写异步代码。

如果要改写前面的例子,应该是这样:

try {     const data = await someAsynchronousFunction(); } catch(err) {     // promise 被拒绝     console.error(err); }

这看起来很像“一般的”同步 JavaScript。大多数流行的JavaScript库和新项目都把 Promises 与 async/await  关键字放在一起用。

但是,如果你要更新现有的库或遇到旧的代码,则可能会对将基于回调的 api 迁移到基于 Promise 的 API  感兴趣,这样可以改善你的开发体验。

来看一下将回调转换为 Promise 的几种方法。

将回调转换为 Promise

Node.js Promise

大多数在 Node.js 中接受回调的异步函数(例如 fs 模块)有标准的实现方式:把回调作为最后一个参数传递。

例如这是在不指定文本编码的情况下用 fs.readFile() 读取文件的方法:

fs.readFile('./sample.txt', (err, data) => {     if (err) {         console.error(err);           return;     }     console.log(data); });

注意:如果你指定 utf-8 作为编码,那么得到的输出是一个字符串。如果不指定得到的输出是 Buffer。

另外传给这个函数的回调应接受 Error,因为它是第一个参数。之后可以有任意数量的输出。

如果你需要转换为 Promise 的函数遵循这些规则,那么可以用 util.promisify ,这是一个原生 Node.js 模块,其中包含对  Promise 的回调。

首先导入ʻutil`模块:

const util = require('util');

然后用 promisify 方法将其转换为 Promise:

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

现在,把新创建的函数用作 promise:

readFile('./sample.txt', 'utf-8')     .then(data => {         console.log(data);     })     .catch(err => {         console.log(err);     });

另外也可以用下面这个示例中给出的 async/await 关键字:

const fs = require('fs'); const util = require('util');  const readFile = util.promisify(fs.readFile);  (async () => {     try {         const content = await readFile('./sample.txt', 'utf-8');         console.log(content);     } catch (err) {         console.error(err);     } })();

你只能在用 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 开始:

const fs = require('fs');  const readFile = (fileName, encoding) => {     return new Promise((resolve, reject) => {         fs.readFile(fileName, encoding, (err, data) => {             if (err) {                 return reject(err);             }              resolve(data);         });     }); }  readFile('./sample.txt')     .then(data => {         console.log(data);     })     .catch(err => {         console.log(err);     });

新函数 readFile() 接受了用来读取 fs.readFile() 文件的两个参数。然后创建一个新的 Promise  对象,该对象包装了该函数,并接受回调,在本例中为 fs.readFile()。

要 reject Promise 而不是返回错误。所以代码中没有立即把数据输出,而是先 resolve 了Promise。然后像以前一样使用基于  Promise 的 readFile() 函数。

接下来看看接受动态数量参数的函数:

const getMaxCustom = (callback, ...args) => {     let max = -Infinity;      for (let i of args) {         if (i > max) {             max = i;         }     }      callback(max); }  getMaxCustom((max) => { console.log('Max is ' + max) }, 10, 2, 23, 1, 111, 20);

第一个参数是 callback 参数,这使它在接受回调的函数中有点与众不同。

转换为 promise 的方式和上一个例子一样。创建一个新的 Promise 对象,这个对象包装使用回调的函数。如果遇到错误,就  reject,当结果出现时将会 resolve。

我们的 promise 版本如下:

const getMaxPromise = (...args) => {     return new Promise((resolve) => {         getMaxCustom((max) => {             resolve(max);         }, ...args);     }); }  getMaxCustom(10, 2, 23, 1, 111, 20)     .then(max => console.log(max));

在创建 promise 时,不管函数是以非标准方式还是带有许多参数使用回调都无关紧要。我们可以完全控制它的完成方式,并且原理是一样的。

关于Node.js中怎么将回调转换为 Promise就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: Node.js中怎么将回调转换为 Promise

本文链接: https://lsjlt.com/news/74247.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Node.js中怎么将回调转换为 Promise
    这篇文章将为大家详细讲解有关Node.js中怎么将回调转换为 Promise,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。什么是回调回调是一个函数参数,恰好...
    99+
    2024-04-02
  • mysql中怎么将varchar转换为integer
    这期内容当中小编将会给大家带来有关mysql中怎么将varchar转换为integer,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 其实转换是很简单的如下代码 de...
    99+
    2024-04-02
  • java中怎么将double转换为int
    在Java中,可以使用强制类型转换将double转换为int。强制类型转换可以通过将目标类型放在要转换的值之前并使用圆括号来实现。 ...
    99+
    2023-10-25
    java
  • C# 中怎么将PDF转换为PDFA
    本篇文章给大家分享的是有关C# 中怎么将PDF转换为PDFA,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。使用类库:Spire.PDF for .NET pack获取及引用:方...
    99+
    2023-06-03
  • c++中怎么将int转换为string
    在C++中,可以使用`std::to_string()`函数将`int`类型转换为`std::string`类型。下面是一个示例:`...
    99+
    2023-08-19
    c++
  • 怎么将html转换为doc
    这篇文章将为大家详细讲解有关怎么将html转换为doc,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。html有什么特点1、简易性:超级文本标记语言版本升级采用超集方式,从而更加灵活方便,适合...
    99+
    2023-06-14
  • 怎么将pdf转换为html
    本篇文章给大家分享的是有关怎么将pdf转换为html,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。先打开pdf格式转换工具,选择转换格式“文件转html“;然后添加要转换的pd...
    99+
    2023-06-15
  • JavaScript中怎么将数值转换为Boolean
    本篇文章给大家分享的是有关JavaScript中怎么将数值转换为Boolean,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。字符串consts...
    99+
    2024-04-02
  • javascript中怎么将数组转换为string
    javascript中怎么将数组转换为string,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 实现方法有:1、...
    99+
    2024-04-02
  • 怎么在golang中将Int转换为string
    这期内容当中小编将会给大家带来有关怎么在golang中将Int转换为string,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。什么是golanggolang 是Google开发的一种静态强类型、编译型、并...
    99+
    2023-06-14
  • 怎么在c#中将DataTable转换为List
    本篇文章为大家展示了怎么在c#中将DataTable转换为List,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。  直接写一个datatable转list的类 利用泛型来写,更加通用pub...
    99+
    2023-06-14
  • 怎么在java中将json转换为Map
    怎么在java中将json转换为Map?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、分布...
    99+
    2023-06-14
  • 怎么在JavaScript中将 string转换为boolean
    这篇文章将为大家详细讲解有关怎么在JavaScript中将 string转换为boolean,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。JavaScript是什么JavaScript是一种...
    99+
    2023-06-14
  • 怎么在python中将series转换为dataframe
    这篇文章将为大家详细讲解有关怎么在python中将series转换为dataframe,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。python是什么意思Python是一种跨平台的、具有解释...
    99+
    2023-06-14
  • 怎么在python中将dataframe转换为ndarray
    这篇文章将为大家详细讲解有关怎么在python中将dataframe转换为ndarray,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。python有哪些常用库python常用的库:1.req...
    99+
    2023-06-14
  • 怎么在Go中将[]byte转换为io.Reader
    这篇文章主要介绍怎么在Go中将[]byte转换为io.Reader,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在 stackoverflow 上看到一个问题,题主进行了一个网络请求,接口返回的是 []byte。如果...
    99+
    2023-06-22
  • 怎么在pytorch中将HWC转换为CHW
    这篇文章给大家介绍怎么在pytorch中将HWC转换为CHW,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。import torchimport numpy as npfrom&n...
    99+
    2023-06-15
  • 怎么在pandas中将NaN转换为None
    怎么在pandas中将NaN转换为None?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。原始数据:示例代码:import pandas as ...
    99+
    2023-06-15
  • php怎么将月份转换为中文
    php将月份转换为中文的方法:1、创建一个PHP示例文件;2、通过“public function dateToChinese($date){...}”方法将日期月份转换为全中文即可。本教程操作环境:Windows10系统、PHP8.1版、...
    99+
    2023-05-14
    php 中文
  • php中怎么怎么将数组转换为xml
    这篇文章给大家介绍php中怎么怎么将数组转换为xml,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。php将数组转为xml的方法:首先创建一个PHP示例文件;然后通过“function data_to_xml($data...
    99+
    2023-06-20
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作