您的位置: 翼速应用 > 业内知识 > web前端 > 正文

一起探讨node中的fs文件系统模块和path路径模块

一起探讨node中的fs文件系统模块和path路径模块

node中的fs文件系统模块和path路径模块



fs文件系统模块


fs 模块是 Node.js 官方提供的、用来操作文件的模块。它提供了一系列的方法和属性,用来满足用户对文件的操作需求。


  1. fs.readFile() 方法,用来读取指定文件中的内容

  2. fs.writeFile() 方法,用来向指定的文件中写入内容 如果要在 JavaScript 代码中,使用 fs 模块来操作文件,则需要使用如下的方式先导入它:


const fs = reuire('fs')


读取指定文件中的内容


1. fs.readFile()的语法格式


使用 fs.readFile() 方法,可以读取指定文件中的内容,语法格式如下:


fs.readFile(path[, options], callback)


  1. 参数1:必选参数,需要指定一个文件路径的字符串,表示要读取哪个路径对应的文件。

  2. 参数2:可选参数,表示以什么编码格式来读取文件。

  3. 参数3:必选参数,文件读取完成后,通过回调函数拿到读取的结果。


2. fs.readFile()的示例代码


以 utf8 的格式,读取指定文件的内容,并打印err 和 data 的值:


const fs = require('fs');

fs.readFile('hello.txt', 'utf-8', (err, data) => {

    // 判断是否读取成功

    if (err) return console.log(err);

    console.log(data); 

});


向指定的文件中写入内容


1. fs.writeFile()的语法格式


使用 fs.writeFile() 方法,可以向指定的文件中写入内容,语法格式如下:


fs.writeFile(file, data[, options], callback)


  • 参数1:必选参数,需要指定一个文件路径的字符串,表示要文件的存放路径。

  • 参数2:必选参数,表示要写入的内容。

  • 参数3:可选参数,表示以什么格式写入文件内容,默认值是utf8。

  • 参数4:必选参数,文件写入完成后的回调函数。


2. fs.writeFile()的示例代码


const fs = require('fs');

fs.writeFile('./hello.txt', 'hello node', (err) => {

    // 判断是否写入成功

    if (err) return console.log(err);

    console.log('写入成功');

});

读取指定目录下所有文件的名称


1.fs.readdir()的语法格式


使用 fs.readdir() 方法,可以读取指定目录下所有文件的名称,语法格式如下:


fs.readdir(path[, options], callback)


  • 参数1:必选参数,表示要读取哪个目录下的文件名称列表。

  • 参数2:可选参数,以什么格式读取目录下的文件名称,默认值是utf8。

  • 参数3:必选参数,读取完成以后的回调函数。


2.fs.readdir()的示例代码


通过 fs.readdir() 方法,可以读取指定目录下,所有文件的名称:


const fs = require('fs');

fs.readdir('./', (err, data) => {

    // 错误处理

    if (err) return console.log(err);

    console.log(data);

});


fs 模块-路径动态拼接的问题


在使用 fs 模块操作文件时,如果提供的操作路径是以./ 或 ../ 开头的相对路径时,很容易出现路径动态拼接错误的问题。 这是因为代码在运行的时候,会以执行node 命令时所处的目录,动态拼接出被操作文件的完整路径。


解决方案:在使用fs 模块操作文件时,直接提供绝对路径,不要提供./ 或 ../ 开头的相对路径,从而防止路径动态拼接的问题。


注意:使用__dirname 获取当前文件所在的绝对路径


const fs = require('fs');

// 拼接要读取文件的绝对路径

let filepath = __dirname +'/hello.txt'

fs.readFile(filepath, 'utf-8', (err, data) => {

    // 判断是否读取成功

    if (err) return console.log(err);

    console.log(data); 

});


path路径模块


path 模块是 Node.js 官方提供的、用来处理路径的模块。它提供了一系列的方法和属性,用来满足用户对路径的处理需求。


  1. path.join() 方法,用来将多个路径片段拼接成一个完整的路径字符串

  2. path.basename() 方法,用来从路径字符串中,将文件名解析出来


如果要在 JavaScript 代码中,使用 path 模块来处理路径,则需要使用如下的方式先导入它:


const path = require('path')


路径拼接


path.join()的语法格式


使用 path.join() 方法,可以把多个路径片段拼接为完整的路径字符串,语法格式如下:


path.join([...paths])


使用 path.join() 方法,可以把多个路径片段拼接为完整的路径字符串:


const path = require('path');

console.log( path.join('a', 'b', 'c') ); // a/b/c

console.log( path.join('a', '/b/', 'c') ); // a/b/c

console.log( path.join('a', '/b/', 'c', 'index.html') ); // a/b/c/index.html

console.log( path.join('a', 'b', '../c', 'index.html') ); // a/c/index.html

console.log(__dirname); // node自带的全局变量,表示当前js文件所在的绝对路径

// 拼接成绩.txt的绝对路径

console.log( path.join(__dirname, '成绩.txt') ); // ------ 最常用的


获取路径中的文件名


1.path.basename()的语法格式


使用 path.basename() 方法,可以获取路径中的最后一部分,经常通过这个方法获取路径中的文件名,语法格式如下:


path.basename(path[,ext])


  1. path 必选参数,表示一个路径的字符串

  2. ext 可选参数,表示可选的文件扩展名

  3. 返回: 表示路径中的最后一部分


2.path.basename()的代码示例


使用 path.basename() 方法,可以从一个文件路径中,获取到文件的名称部分:


// 找文件名

console.log( path.basename('index.html') ); // index.html

console.log( path.basename('a/b/c/index.html') ); // index.html

console.log( path.basename('a/b/c/index.html?id=3') ); // index.html?id=3

console.log(path.basename('/api/getbooks')) // getbooks


获取路径中的文件扩展名


1.path.extname()的语法格式


使用 path.extname() 方法,可以获取路径中的扩展名部分,语法格式如下:


path.extname(path)


  1. path 必选参数,表示一个路径的字符串

  2. 返回: 返回得到的扩展名字符串


使用 path.extname() 方法,可以获取路径中的扩展名部分


// 找字符串中,最后一个点及之后的字符

console.log( path.extname('index.html') ); // .html

console.log( path.extname('a.b.c.d.html') ); // .html

console.log( path.extname('asdfas/asdfa/a.b.c.d.html') ); // .html

console.log( path.extname('adf.adsf') ); // .adsf



以上就是这篇文章的全部内容了,翼速应用平台内有更多相关资讯,欢迎关注!

我来说两句

0 条评论

推荐阅读

  • 响应式布局CSS媒体查询设备像素比介绍

    构建响应式网站布局最常见的是流体网格,灵活调整大小的站点布局技术,确保用户在使用的幕上获得完整的体验。响应式设计如何展示富媒体图像,可以通过以下几种方法。

    admin
  • 提升网站的性能快速加载的实用技巧

    网站速度很重要,快速加载的网站会带来更好的用户体验、更高的转化率、更多的参与度,而且在搜索引擎排名中也扮演重要角色,做SEO,网站硬件是起跑线,如果输在了起跑线,又怎么跟同行竞争。有许多方法可提升网站的性能,有一些技巧可以避免踩坑。

    admin
  • 织梦CMS TAG页找不到标签和实现彩色标签解决方法

    织梦cms是我们常见的网站程序系统的一款,在TAG标签中常常遇到的问题也很多。当我们点击 tags.php 页的某个标签的时候,有时会提示:“系统无此标签,可 能已经移除!” 但是我们检查程序后台,以及前台显示页面。这个标签确实存在,如果解决这个问题那?

    admin
  • HTML关于fieldset标签主要的作用

    在前端开发html页面中常用的标签很多,今天为大家带来的是关于HTML中fieldset标签主要的作用说明,根据技术分析HTML

    admin

精选专题