当前位置: 首页 > news >正文

Nodejs回调函数

1、参考:Node.js 回调函数 | 菜鸟教程

2、实践截图:

2.1、阻塞代码实例

var fs = require("fs");

var data = fs.readFileSync('input.txt');

console.log(data.toString());
console.log("程序执行结束!");

2.2、非阻塞代码实例

var fs = require("fs");

fs.readFile('input.txt', function (err, data) {
    if (err) return console.error(err);
    console.log(data.toString());
});

console.log("程序执行结束!");

2.3、回调地狱(Callback Hell)

var fs = require("fs");

fs.readFile('file1.txt', 'utf8', (err, data1) => {
    if (err) {
        console.error('Error reading file1:', err);
        return;
    }

    fs.readFile('file2.txt', 'utf8', (err, data2) => {
        if (err) {
            console.error('Error reading file2:', err);
            return;
        }

        fs.readFile('file3.txt', 'utf8', (err, data3) => {
            if (err) {
                console.error('Error reading file3:', err);
                return;
            }

            console.log('Data from all files:', data1, data2, data3);
        });
    });
});

console.log("程序执行结束!");

2.4、使用 async/await

const fs = require('fs').promises;

async function readFiles() {
    try {
        const data1 = await fs.readFile('file1.txt', 'utf8');
        const data2 = await fs.readFile('file2.txt', 'utf8');
        const data3 = await fs.readFile('file3.txt', 'utf8');

        console.log('Data from all files:', data1, data2, data3);
    } catch (err) {
        console.error('Error reading files:', err);
    }
}

readFiles();

console.log("程序执行结束!");

2.5、使用 promises

const fs = require('fs').promises;

fs.readFile('file1.txt', 'utf8')
    .then(data1 => {
        console.log('Data from file1:', data1);
        return fs.readFile('file2.txt', 'utf8');
    })
    .then(data2 => {
        console.log('Data from file2:', data2);
        return fs.readFile('file3.txt', 'utf8');
    })
    .then(data3 => {
        console.log('Data from file3:', data3);
    })
    .catch(err => {
        console.error('Error reading files:', err);
    });

console.log("程序执行结束!");

相关文章:

  • 外贸机械网站建设网页制作培训教程
  • Wordpress页面添加小工具宁波seo教程app推广
  • 北京创意网站建设seo站内优化和站外优化
  • 达内培训网站开发查排名的网站
  • 虾米音乐歌曲链接做qq音乐网站seo是什么品牌
  • vi设计毕业论文范文seo云优化如何
  • 使用uglifyjs对静态引入的js文件进行压缩
  • 网络安全小知识课堂(十三)
  • css专题1-----给div盒子的边框添加阴影
  • 地质科研智能革命:当大语言模型“扎根”地质现场、大语言模型本地化部署与AI智能体协同创新实践
  • 项目管理中客户拒绝签字验收?如何处理和预防
  • ModelScope能干什么?
  • Java Comparable 接口详解
  • 在Windows搭建gRPC C++开发环境
  • 局域网访问 Redis 方法
  • springmvc:tomcat启动无报错但接口404问题排查
  • 国标GB28181视频平台EasyCVR顺应智慧农业自动化趋势,打造大棚实时视频监控防线
  • 2025上海CMEF:鱼跃以“AI+医疗”开启健康管理新纪元
  • java基础 流(Stream)
  • 按键++,--在操作uint8_t类型(一个取值为1~10的数)中,在LCD中显示两位数字问题
  • Vue知识点(5)-- 动画
  • 大脑功能与结构的解耦揭示了人类大脑的区域行为专门化
  • 实习技能记录【2】-----LVGL[基本概念]
  • opencv无法设置禁用RGB转换问题
  • centos练习docker<基础>
  • 蓝桥杯第十一届省赛C++B组真题解析