首先附上node官网fs模块地址:fs 文件系统 | Node.js v20 文档
1. 写入 writeFile
这里直接封装了一个函数,代码附上:
const write = (url, data) => {
fs.writeFile(url, data, function (err) {
if (err) {
return console.log('写入失败' + err.message);
}
console.log('写入成功')
})
}
参数解读:
参数1: url ( 你想写入的文件位置 )
tips: 这里可以使用绝对路径也可以使用相对路径
有的老铁相对路径写完可能会报错文件路径不对
绝对路径方法附上:
path.join(__dirname,'xxx.xxx')
参数2: data ( 写入的数据 )
tips: “data”参数的类型必须是字符串或Buffer、TypedArray或DataView的实例
如果你出现 The "data" argument must be of type string or an instance of Buffer, TypedArray, or DataView. 这个报错提示,不用怀疑,data的格式不对
这边建议直接用json格式的数据来储存,原因后续说明,这里直接将json数据转换为string即可
方法附上:
JSON.stringify(jsonData)
2. 读取 readFile
同样这里也是封装成函数使用,代码附上
const read = (url) => {
fs.readFile(url, 'utf8', function (err, dataStr) {
if (err) {
return console.log('读取失败' + err.message)
}
// 数据处理或其他操作
})
}
参数解读:
参数1: url 与写入的一致
参数2: dataStr 为所读取到的数据
读取遇到的问题1:
读取到的数据自身的格式失效
讲人话: 就是看起来是json格式的数据,但是它的本质是字符串
tips: 导致的原因与所读取的文件类型有关(.txt, .config都一样),若读取 .json文件即可正常使用
这里使用json格式的数据的好处就出现了,因为可以对这个格式的数据进行转换,方法附上
JSON.parse(dataStr)
读取遇到的问题2:
在使用readFile读取时,此行为为异步操作,若不想在回调函数内进行数据操作,则需处理此行为
查阅官网知 readFileSync 此方法也是读取文件且为同步操作(官网开头已提供)
因此改写代码,新函数如下:
const read = (url) => {
try {
return JSON.parse(fs.readFileSync(url, 'utf8'))
} catch (error) {
return console.log('读取失败', error)
}
}
解释一下此处为什么使用try catch, 如果你输入的 url 错误或不存在的话,会导致代码直接崩掉,使用try catch后可以捕获到这个bug,增加代码的稳固性