通过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')