一、什么是path路径模块
path模块是Node.js官方提供的、用来处理路径的模块。它提供了一系列的方法和属性,用来满足用户路径的处理需求。
例如:
-
path.join()方法
,用来将多个路径片段拼接成一个完整的路径字符串 -
path.basename()方法
,用来从路径字符串中,将文件名解析出来
如果要在JavaScript代码中,使用path模块来处理路径,则需要使用如下的方式先导入它:
const path = require('path')
二、path.join()的语法格式
使用path.join()方法,可以把多个路径片段拼接为完整的路径字符串,语法格式如下:
path.join([...paths])
参数解读:
- ...paths<string>路径片段的序列
- 返回值:<string>
path.join()代码案例
使用path.join()方法,可以把多个路径片段拼接为完整的路径字符串:
const pathStr = path.join('a', '/b/c', '../', './d', 'e')
console.log(pathStr) //输出 a/b/d/e
提醒:如上'../'属于特殊的路径,它会抵消让它前面一个不起作用,此时他前面是c,所以输出的结果里面并不包含c,那如果是'../../'则会抵消两个,结果就是a/d/e,由此可得知,有几个../就会往前面抵消几个路径。那么'./'是不会抵消路径的。
const pathStr2 = path.join(__dirname, '/html拓展标签.html')
console.log(pathStr2) //输出 当前文件所处目录/html拓展标签.html
将此方法,去读取文件:
const pathStr2 = path.join(__dirname, '/html拓展标签.html')
fs.readFile(pathStr2, 'utf8', function (err, dataStr) {
if (err) {
return console.log('读取文件失败!' + err.message)
}
console.log('读取文件成功!' + dataStr)
})
上一章节,我们采取的是用加号的形式去拼接,现在我们采取path.join()方法进行拼接,会有一个好处,即使我们在路径前面多加了点,path.join()方法会自动屏蔽点。就比如path.join(__dirname, './a/b')
,就会省略a前面的点,但如果我们不是用path.join()方法,采用加号拼接就不会屏蔽点,就比如__dirname+'./a/b'
,就是错的。
注意:今后凡是涉及到路径拼接的操作,都要是用path.join()方法进行处理。不要直接使用+进行字符串的拼接。
三、path.basename()的语法格式
使用path.basenamme()方法,可以获取路径中的最后一部分,经常通过这个方法获取路径中的文件名,语法格式如下:
path.basename(path[.ext])
参数解读:
- path<string>必须参数,表示一个路径的字符串
- ext<string>可选参数,表示文件拓展名
- 返回:<string>表示路径中的最后一部分
path.basename()代码案例
使用path.basename()方法,可以从一个文件路径中,获取到文件的名称部分:
一、只有一个参数的情况(只包含路径):
const fpath = 'a/b/c/index.html' //文件的存放路径
var fullName = path.basename(fpath)
console.log(fullName) //输出 index.html
二、传递两个参数(路径以及后缀名)
const fpath = 'a/b/c/index.html' //文件的存放路径
var nameWithoutExt = path.basename(fpath, '.html')
console.log(nameWithoutExt) //输出 index
总结:如果你只想获取文件的名称,只要传递文件的存放路径即可,如果你不想带上文件的后缀名,只需要传递第二个参数,将参数名传递过去,就能获取到文件名不包含拓展的情况
四、path.basename()的语法格式
使用path.extname()方法,可以获取路径中的扩展名部分,语法格式如下:
path.extname(path)
参数解读:
- path <string> 必选参数,表示一个路径的字符串
- 返回:<string>返回得到的扩展名字符串
path.extname()代码案例
使用path.extname()方法,可以获取路径的扩展名部分:
const fpath = '/a/b/c/index.html'
const fext = path.extname(fpath)
console.log(fext) //输出.html
总结:path的一些用法,目前介绍的都是比较简单的,可以即使消化一下,多学一点,每天进步一点,都是极好的的。推荐一首歌《窒息》