Node.js中进行读写文件的操作及代码是什么
Admin 2022-08-22 群英技术资讯 311 次浏览
操作文件是服务端一个基础的功能,也是做后端开发的必备能力之一。
操作文件主要包括读和写。而这些功能 Nodejs 都已经提供了对应的方法。只要调用就行了。
同步方法
const fs = require('fs') fs.mkdirSync(`${__dirname}/雷猴`)
NodeJS
有一个文件模块,叫 fs
。对文件操作的话,必须先引入这个模块。
使用 fs.mkdirSync
方法可以创建一个文件夹。里面传入要创建的文件夹的名字即可。
__dirname
指的是当前文件所在文件夹的绝对路径。
异步创建
const fs = require('fs') fs.mkdir(`${__dirname}/雷猴`, err => { if (err) { console.error(err) } })
使用 fs.mkdir
方法可以进行异步创建,第一个参数也是文件夹名称,第二个是回到函数,该函数里有一个 err
参数,可以返回错误信息。
创建完文件夹,本来是想讲 “删除文件夹” 的。但由于删除文件夹之前要清空里面所有文件,所以就把 删除文件 的用法放在前面讲。
删除文件分 同步 和 异步 两种方法。
同步 fs.unlinkSync
const fs = require('fs') fs.unlinkSync(`${__dirname}/test.txt`);
fs.unlinkSync
里传入要删除的文件路径和文件名,即可删除指定文件。
异步 fs.unlink
const fs = require('fs') fs.unlink(`${__dirname}/test.txt`, err => { if (err) { console.error(err) } })
fs.unlink
方法有2个参数,第一个参数是文件路径和文件名,第二个参数是监听删除失败的回调函数。
删除文件夹之前要清空目标文件夹里的所有文件。 可以使用 fs.unlinkSync
或 fs.unlink
删除文件。
同步
const fs = require('fs') fs.rmdirSync(`${__dirname}/雷猴`)
异步
const fs = require('fs') fs.rmdir(`${__dirname}/雷猴`, err => { if (err) { console.error(err) } })
和删除文件的用法差不多,删除文件夹的方法也有同步和异步,异步接受2个参数,第二个参数同样是监听报错的回调。
const fs = require('fs') const content = ' 雷猴雷猴\n' const opt = { flag: 'a', // a:追加写入;w:覆盖写入 } fs.writeFile('test.txt', content, opt, (err) => { if (err) { console.error(err) } })
fs.writeFile
方法可以将内容写入文件中。如果文件不存在,会自动创建文件。
fs.writeFile
参数说明:
const fs = require('fs') fs.readFile('fileName', (err, data) => { if (err) { console.error(err) return } // data 是二进制类型,需要转换成字符串 console.log(data.toString()) })
使用 fs.readFile
方法可以读取数据,第一个参数是文件名;第二个参数是回调,err
监听错误信息,data
是读取回来的数据。
需要注意的是,读取回来的 data
是一个二进制类型的数据,需要使用 toString()
方法转换成我们读得懂的数据。
const fs = require('fs') const exist = fs.existsSync('fileName') console.log(exist)
使用 fs.existsSync
方法可以检测指定文件是否存在,如果存在就返回 true
;否则返回 false
。
如果你使用 NodeJS
做后台,读写文件这块知识点是逃不过去的。它最常见的功能可以写日志,比如收集错误日志等。
日志我们也可以写在数据库里,不过不是所有电脑都装了相同的数据库。但如果你将日志写在一个文件中,文件的内容在别的电脑一般都能轻易打开。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
vue全局水印怎么设置?对于创建水印相信大家应该都陌生,今天我们来了解以下vue全局水印的方法,下文有详细的实例供大家参考,感兴趣的朋友就跟随小编一起来学习一下吧。
这篇文章主要为大家介绍了Vue搭建Vuex环境,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
这篇文章主要介绍了vue-quill-editor插入图片路径太长问题解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
众所周知,使用element-ui,为了达到减小项目体积的目的 ,我们在实际项目中更多的是采用按需引入的方法, 下面就来讲讲那些我踩过的坑。步骤:第一步:安装 element-ui 时把 element 也安装一下,执行命令 npm i element-ui -S 和 npm i element -S第二步:安装 ba
each()函数封装了十分强大的遍历功能,使用也很方便,它可以遍历一维数组、多维数组、DOM, JSON 等等,这篇文章我们来了解jQuery中each的基本用法,下文有示例供大家参考,有需要的朋友可以看一看,接下来就跟随小编来一起学习一下吧!
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008