path 模块是 nodejs 中用于处理文件/目录路径的一个内置模块,能够看做是一个工具箱,提供诸多方法供咱们使用,固然都是和路径处理有关的。同时在前端开发中 path 模块出现的频率也是比较高的,好比配置 webpack 的时候等。本文是对该模块中一些经常使用的方法进行介绍,走,一块儿学习下吧。css
const path = require('path');
复制代码
const path = require("path");
path.basename('./ext/test.js') //test.js
path.basename('./ext/test.js','.js') //test (当后缀名与文件名匹配上时返回的文件名会省略文件后缀)
path.basename('./ext/test.js','.html') //test.js (没有匹配上时返回文件全名)
path.basename('./ext/foo/') // foo (尾部目录分隔符被忽略)
复制代码
const path = require("path");
path.dirname('./foo/bar/baz'); //./foo/bar (相对路径/绝对路径都可)
path.dirname('/foo/bar/baz/'); // /foo/bar (尾部目录分隔符被忽略)
path.dirname('/foo/bar/baz/test.js'); // /foo/bar/baz
复制代码
const path = require("path");
path.extname('foo/bar/baz/test.js'); // .js
path.extname('foo/bar/baz');// '' (无扩展名返回 '')
path.extname('foo/bar/baz/.'); // ''
path.extname('foo/bar/baz/test.'); // '.'
path.extname('foo/bar/baz/.test'); // ''
path.extname('foo/bar/baz/.test.js'); // '.js'
复制代码
┌──────────────────┬────────────┐
│ dir │ base │
├──────┬ ├──────┬─────┤
│ root │ │ name │ ext │
" / foo/bar/baz/ index .js "
复制代码
const path = require("path");
path.parse('/foo/bar/baz/index.js')
// {
// root: '/',
// dir: '/foo/bar/baz',
// base: 'index.js',
// ext: '.js',
// name: 'index'
// }
path.parse('/foo/bar/baz') //尾部目录分隔符省略
// {
// root: '/',
// dir: '/foo/bar',
// base: 'baz',
// ext: '',
// name: 'baz'
// }
path.parse('./foo/bar/baz/index.js') //当路径为相对路径 ./ 或../时 解析结果中root(表明根目录,绝对路径才有值)为 ''
// {
// root: '',
// dir: './foo/bar/baz',
// base: 'index.js',
// ext: '.js',
// name: 'index'
// }
复制代码
path.format(pathObj) 序列化 path 路径,与 path.parse() 恰好相反html
注意:前端
const path = require("path");
path.isAbsolute('//foo'); // true
path.isAbsolute('\\\\foo'); // true
path.isAbsolute('C:/foo/..'); // true
path.isAbsolute('C:\\foo\\..'); // true
path.isAbsolute('./bar\\baz'); // false
path.isAbsolute('../bar/baz'); // false
path.isAbsolute('.'); // false
path.isAbsolute(''); // false
复制代码
const path = require("path");
path.join('') // '.'
path.join('./') // '.\'
path.join('../') // '..\'
path.join('/foo/','bar','baz','../','index.js') // '\foo\bar\index.js'
path.join('./bar','baz' ,'/','../','',index.js') // 'bar\index.js'
path.join('foo', {}, 'bar'); // 'TypeError: Path must be a string. Received {}'
复制代码
const path = require("path");
path.normalize('') // '.'
path.normalize('temp//foo//bar//..//'); // temp\foo\
path.normalize('C:////temp\\\\/\\/\\/foo/bar') // C:\temp\foo\bar
path.normalize('..////foo//\bar/baz/') // ..\fooar\baz\ (转义字符出现)
path.normalize('temp//foo/\bar') // temp\fooar (转义字符出现)
复制代码
const path = require("path");
//当前工做目录为 \Stone\node\node\path_module
path.relative('/foo/bar/baz','/foo/bar/dir/file.js') // ..\dir\file.js
path.relative('/foo/bar/baz','/foo/bar/baz') // ''
path.relative('/foo/bar/baz/files.js','') // ..\..\..\..\Stone\node\node\path_module
path.relative('','/foo/bar/baz/files.js') // ..\..\..\..\foo\bar\baz\files.js
path.relative('','./foo/bar/baz/files.js') // foo\bar\baz\files.js
复制代码
这里针对 from 或 to 任何一方为空,则使用当前工做目录代替其空路径。
稍做说明下, 例如当前工做目录为 \Stone\node\node\path_module
,则能够看到 path.relative('/foo/bar/baz/files.js','')
的输出结果为..\..\..\..\Stone\node\node\path_module
,此时 to 为 \Stone\node\node\path_module
, 要输出 to 相对于 from 的相对路径,则 from 须要先 ../ 的形式 一层一层退出,来检索与 to 的公共父级目录,直到遇到公共父级目录或者到根目录中止,而后cd 进 to 目录。这是针对另外一方为绝对路径,若是另外一方为相对路径,则直接就是当前另外一方路径。node
const path = require("path");
//当前工做目录为 \Stone\node\node\path_module
path.resolve('/foo/bar', './baz'); // '/foo/bar/baz'
path.resolve('/foo/bar','', '/tmp/file/'); //'/tmp/file'
path.resolve('root', 'foo/baz/', '../fun/bar') // '\Stone\node\node\path_module\root\foo\fun\bar'
path.resolve() // '\Stone\node\node\path_module'
复制代码
path.resolve 方法解析路径片断的时候会从右往左的顺序依次解析,直到构造出一个绝对路径,不然会将当前工做目录加在路径开头。因此,经过 resolve 解析生成的路径必定是绝对路径。这个方法使用的很是多,应该特眼熟,对,前端咱们配置 webpack 的时候会高频率用到,而且每每还会结合 __dirname
使用。webpack
咱们先在 path_module
目录下运行 node test.js
命令web
<!--当前执行文件的完整路径为\Stone\node\node\path_module\test.js-->
const path = require("path");
console.log(__dirname); // \Stone\node\node\path_module
console.log(__filename); // \Stone\node\node\path_module\test.js
复制代码
而后咱们在 \Stone\node\node
目录下运行 node path_module\test.js
,会发现输出结果同上, 因此这就是说明 __dirname 和 __filename 始终跟当前执行文件有关,跟启动脚本所在目录无关。windows
./
和 ../
咱们都知道是相对路径的写法,可是使用的过程当中配合 require() 使用与否的结果是不一样的。api
<!--当前启动脚本的执行命令所在目录 \Stone\node\node\fs_module\test.js-->
const fs = require('fs')
fs.readFileSync('./ext/test1.js',(err,data)=> {
console.log('ok')
})
复制代码
会正常打印出 okbash
<!--当前启动脚本的执行命令所在目录 \Stone\node\node-->
const fs = require('fs')
fs.readFile('./ext/test1.js',(err,data)=> {
console.log('ok')
})
复制代码
运行会报错 no such file or directory, open './ext/test1.js'
工具
这究竟是为啥嘞,缘由就是 './' 和 '../' 的路径表示意义须要分状况,当结合 require() 使用的时候相对于当前执行文件,若是不结合 require() 使用的状况下会相对于当前启动脚本的目录,所以只有在 require() 时才使用相对路径(./, ../) 的写法,其余地方一概使用绝对路径,这点必定要注意。
关于nodejs path 模块,咱们今天就说到这里了,虽然 api 不是不少,可是 path 模块在前端的使用频率仍是很是高的,因此以为很值得学习了解一下的。因为认知有限,本文如有不许确之处还望路过的各位兄台及时指正,吃瓜,吃瓜。