引入模块
var fs=require("fs");
API
1.fs.readFile(path[, options], callback) 异步地读取文件的全部内容。
- path 读取文件的路径
- options 可以是字符串 ,可以是对象。如果是字符串,默认作为编码格式。这个参数可设置的如下
encoding 设置编码格式,如没有设置这个参数,则默认为"null" ,返回原始的 buffer。
flag 文件系统标志 ,默认为"r"。(具体用法参考第2条方法中的内容) - callback 回调函数 ,回调会传入两个参数 (err, data),其中 data 是文件的内容。
var fs=require("fs");
fs.readFile("./a.txt","utf8",(err,data)=>{
if(err){
console.log(err);
}else{
console.log(data)
}
})
另外,fs.readFile() 函数会缓冲整个文件。 为了最小化内存成本,尽可能通过 fs.createReadStream() 进行流式传输。
2. fs.writeFile(file, data[, options], callback) 异步地将数据写入到一个文件
file 文件名或文件描述符
data 写入的数据
options 可以是对象 ,也可以是字符串。可设置参数如下 (只列举了常见的)
encoding 编码格式,默认值: 'utf8'(注意:如果 data 是一个 buffer,则 encoding 选项会被忽略。)
flag 文件系统标志 ,默认为'w' 。可以设置的参数查阅文档 文件系统标志callback 回调函数,有一个参数err
fs.writeFile("data/a.txt","你好",(err)=>{
if(err){
console.log(err);
}else{
console.log("写入成功!")
}
})
注意
当多次执行写入时,前面的内容会被覆盖,如下:
但是文件中只有一个“你好”,如下:
此时就可以在options位置上设置flag ,如下:
fs.writeFile("data/a.txt","你好",{flag:'a'},(err)=>{
if(err){
console.log(err);
}else{
console.log("追加成功!")
}
})
另外,在同一个文件上多次使用 fs.writeFile()
且不等待回调是不安全的。 对于这种情况,建议使用fs.createWriteStream()
3.fs.readFileSync(path[, options]) 同步返回 path 的内容 (用的不多)
- path 文件名或文件描述符。
- options : encoding /flag
4.fs.writeFileSync(file, data[, options]) (用的不多)
- file 文件名或文件描述符
- data 要写入的数据
- options :encoding /flag (常见)