今天,借助ChatGPT继续学习Node.js,重点是异步编程。这是 Node.js 中最重要的概念之一,我很高兴能够开始掌握它。
理论
在 Node.js 中,异步编程因其非阻塞、事件驱动的架构而至关重要。这意味着文件读取、数据库查询或网络请求等操作在等待结果时不会阻塞其他代码的执行。
我们探索了处理异步操作的三种主要方法:
回调: 作为参数传递给其他函数的函数,异步操作完成后执行。
const fs = require('fs'); fs.readFile('example.txt', 'utf8', (err, data) => { if (err) { console.error(err); return; } console.log(data); });
Promises: 表示异步操作的最终完成(或失败)及其结果值的对象。与嵌套回调相比,Promise 允许链接并使代码更具可读性。
const fs = require('fs').promises; fs.readFile('example.txt', 'utf8') .then(data => { console.log(data); }) .catch(err => { console.error(err); });
Async/Await: 构建在 Promise 之上的语法糖,允许以同步方式编写异步代码。
const fs = require('fs').promises; async function readFile() { try { const data = await fs.readFile('example.txt', 'utf8'); console.log(data); } catch (err) { console.error(err); } } readFile();
实际任务
今天,我练习将基于回调的函数转换为基于 Promise 的函数。
带有回调的原始代码:
const fs = require('fs'); function readFileCallback(path, callback) { fs.readFile(path, 'utf8', (err, data) => { if (err) { callback(err); return; } callback(null, data); }); } readFileCallback('example.txt', (err, data) => { if (err) { console.error(err); return; } console.log(data); });
转换为承诺:
const fs = require('fs').promises; function readFilePromise(path) { return fs.readFile(path, 'utf8'); } readFilePromise('example.txt') .then(data => { console.log(data); }) .catch(err => { console.error(err); });
独立任务
我还使用 async/await 编写了一个异步函数,它读取文件的内容并将其记录到控制台。如果发生错误(例如,找不到文件),它应该捕获错误并记录它。
const fs = require('fs').promises; async function readFileAsync(path) { try { const data = await fs.readFile(path, 'utf8'); console.log(data); } catch (err) { console.error(err); } } readFileAsync('example.txt');
资源
ChatGPT 创建的所有课程均可在以下位置找到:https://king-tri-ton.github.io/learn-nodejs
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3