Node.js基础篇-02调试+模块(Module)+文件模块基本使用

通过console.log进行调试需要编辑源码,要在源码中添加很多调试语句去排查错误,这种打印语句方法调试在运行的应用程序只能获得局部的信息,不能查看整体运行状况

node inspect index.js

解决之前的问题很简单,就是使用node.js自带的调试工具使用命令node inspect index.js即可进行调试,输入命令之后,会进入可交互的命令行进行调试 以下是常用的调试命令 设置断点,在调试启动后可以通过setBreakPoint(行数),在指定行数进行断点

模块(Module)

Node.js的基本结构 其中核心部分是V8引擎和一些额外的库,如libuv和openssl 这一层的是通过C++编写的,用于表示运行环境,开发者大多数不会直接接触这层 围绕核心平台这层,叫节点绑定,代表C++和JavaScript之间的转换,这部分可以使Node.js自身的一部分通过JavaScript实现 最后一层,标准库层,由核心模块组成,这层可以直接进行应用开发

核心模块

用自带的核心模块去搭建一个Node.js应用程序,这个地址就可以给你所有 nodejs.org/api/ ,这个是当前版本Node.js所有接口的文档 文档中还很清晰用颜色告诉你哪些是稳定的,哪些是废弃的、哪些是实验阶段的

加载一个核心模块

加载一个核心模块也很简单比如,打印一个以秒为单位的系统正常运行时间

javascript 复制代码
import {uptime} from 'os'
console.log(uptime());

path模块

需要引入内置path模块 1、常用方法 拼接路径

lua 复制代码
console.log(path.join('a', 'd', 'c'))

拼接路径返回绝对路径,传入相对路径Node会根据当前的环境进行绝对路径的拼接

lua 复制代码
console.log(path.resolve('abcd', 'k'))
console.log(path.resolve('efgh', 's'))

返回目录名:path.dirname 获取文件名(包含扩展名):path.basename 获取扩展名:path.extname

文件系统

fs(file system)文件系统,用于操作文件和目录 支持同步、异步调用,同步会阻塞线程,异步不会阻塞线程 同步写法

ini 复制代码
const fileData = fs.readFileSync('./text.txt', 'utf-8')
console.log(fileData);

异步写法

javascript 复制代码
fs.readFile('./text.txt', 'utf-8', (err, data) => {
  console.log(data);
})

整体代码

javascript 复制代码
// index.js
const fs = require('fs')
const express = require('express')


const app = express()
const port = 3000

app.get('/', (req, res) => {
  res.send('Hello World!')
})

const fileData = fs.readFileSync('./text.txt', 'utf-8')
console.log(fileData);

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

运行结果,可以看出同步在aaa输出完成之前会阻塞线程,异步不会 写入文件 参数1:输出文件路径 参数2:输出内容 参数3(可选):编码格式

arduino 复制代码
fs.writeFileSync('./abc.txt', 'hahahhahahhah')
相关推荐
Livingbody43 分钟前
Fast Whisper 语音转文本
后端
程序员岳焱1 小时前
深度剖析:Spring AI 与 LangChain4j,谁才是 Java 程序员的 AI 开发利器?
java·人工智能·后端
G探险者1 小时前
《深入理解 Nacos 集群与 Raft 协议》系列五:为什么集群未过半,系统就不可用?从 Raft 的投票机制说起
分布式·后端
G探险者1 小时前
《深入理解 Nacos 集群与 Raft 协议》系列一:为什么 Nacos 集群必须过半节点存活?从 Raft 协议说起
分布式·后端
G探险者1 小时前
《深入理解 Nacos 集群与 Raft 协议》系列四:日志复制机制:Raft 如何确保提交可靠且幂等
分布式·后端
G探险者1 小时前
《深入理解 Nacos 集群与 Raft 协议》系列三:日志对比机制:Raft 如何防止数据丢失与错误选主
分布式·后端
G探险者1 小时前
《深入理解 Nacos 集群与 Raft 协议》系列二:Raft 为什么要“选主”?选主的触发条件与机制详解
分布式·后端
我的golang之路果然有问题1 小时前
云服务器部署Gin+gorm 项目 demo
运维·服务器·后端·学习·golang·gin
Java水解1 小时前
彻底解决Flask日志重复打印问题:从原理到实践
后端·flask
Nick同学1 小时前
GatewayWorker 使用总结
后端·php