nodejs入门API之path模块

时间:2021-07-26 14:02:05
  • Path模块在各个系统上的差异
  • Path模块API解析

一、Path模块在各个系统上的差异

path模块提供用于处理文件路径和目录路径的使用工具。

let path = require('path')

由于node.js应用程序运行所在的系统不一样会导致path获取的路径风格不一致。比如windows与Unix上的POSIX系统操作接口就会有如下差别:

//比如path.basename()获取路径最后一部分的差异
path.basename('C:\\temp\\myfile.html');
// POSIX -- 返回: 'C:\\temp\\myfile.html'
// Windows -- 返回: 'myfile.html' //比如path.delimaiter路径界定符的差异
console.log(process.env.PATH);
// POSIX -- 打印: '/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin'
// Windows -- 打印: 'C:\Windows\system32;C:\Windows;C:\Program Files\node\'

除了获取的数据值的差异,还有比如在示例中可以看到的路径定界符的差异,windows上可以有(“\\”,“//”,“/”),在POSIX系统上都采用(“/”)。

还有就是在posix系统上使用path使用path.posix属性来指定调用posix系统模式下的方法,详细见第三节3.2和3.4的内容。

二、Path模块API解析(方法)

2.1 path.basename(path[,ext]):

用来获取路径指向的节点名称。

path<string>:路径字符

ext<string>:可选扩展名;指定路径名获得路径最后一部分的获取结果会省略后缀

path.basename('/foo/bar/baz/asdf/quux.html');
// 返回: 'quux.html'
path.basename('/foo/bar/baz/asdf/quux.html', '.html');
// 返回: 'quux'

2.2 path.dirname(path)

用来获取当前路径所在目录,也就不包含最后一个路径节点和路径分隔符。

 //示例一
path.dirname('/foo/bar/baz/asdf/quux');
// 返回: '/foo/bar/baz/asdf' //示例二
path.dirname("/foo/path/index.js");
// 返回: '/foo/path'

3.3 path.extname(path)

用来获取路径扩展名。

 path.extname('index.html');
// 返回: '.html'
path.extname('index.coffee.md');
// 返回: '.md'
path.extname('index.');
// 返回: '.'
path.extname('index');
// 返回: ''
path.extname('.index');
// 返回: ''
path.extname('.index.md');
// 返回: '.md'

2.4 path.format(pathObject)

将路径对象转换成路径字符串。对象属性包含:dir、root、base、name、ext。注意如果是使用根路径root需要在末尾添加路径分隔符,如果使用文件类型需要在文件类型名称前添加点“.”。

  • 如果提供了 pathObject.dir,则忽略 pathObject.root。(使用root时需要在尾部添加路径分隔符)
  • 如果 pathObject.base 存在,则忽略 pathObject.ext 和 pathObject.name

还需要注意在windows上拼接字符串时,手动写入分隔符时需要写入双反斜杠(\\),这在第一节的示例中已经可以看到相关内容。

 //windows上的示例
let path = require("path");
console.log( path.format({root:"root\\",name:"name",ext:".ext"}));//root\name.ext
console.log( path.format({dir:"dir",name:"name",ext:".ext"}));//dir\name.ext
console.log( path.format({root:"root\\",base:"base.txt"}));//root\base.txt
console.log( path.format({dir:"dir",base:"base.txt"}));//dir\base.txt

2.5 path.isAbsolute(path):

检测路径是否是绝对路径。

 //windows上的示例
let path = require("path");
path.isAbsolute('//server'); // true
path.isAbsolute('\\\\server'); // true
path.isAbsolute('C:/foo/..'); // true
path.isAbsolute('C:\\foo\\..'); // true
path.isAbsolute('bar\\baz'); // false
path.isAbsolute('bar/baz'); // false
path.isAbsolute('.'); // false //POSIX
path.isAbsolute('/foo/bar'); // true
path.isAbsolute('/baz/..'); // true
path.isAbsolute('qux/'); // false
path.isAbsolute('.'); // false

2.6 path.join([...path]):

将路径片段使用平台特定的分隔符作为定界符连接起来,生成符合平台规范的路径字符串。

path.join('/foo', 'bar', 'baz/asdf', 'quux', '..');
// 返回: '/foo/bar/baz/asdf' path.join('foo', {}, 'bar');
// 抛出 'TypeError: Path must be a string. Received {}'

2.7 path.nornalize(path):

将传入的不规范的路径字符串处理成规范的路径字符串。比如在路径字符串中出现连续的多个定界符,可以通过nornalize()处理转换成标准的符合规范的路径字符串,比如示例:

 //例如,在 POSIX 上:
path.normalize('/foo/bar//baz/asdf/quux/..');
// 返回: '/foo/bar/baz/asdf' //在 Windows 上:
path.normalize('C:\\temp\\\\foo\\bar\\..\\');
// 返回: 'C:\\temp\\foo\\' path.win32.normalize('C:////temp\\\\/\\/\\/foo/bar');
// 返回: 'C:\\temp\\foo\\bar'

2.8 path.parse(path):

将路径字符串转换成路径对象。(末尾的路径定界符会被忽略)

 //在 POSIX 上:
path.parse('/home/user/dir/file.txt');
// 返回:
// { root: '/',
// dir: '/home/user/dir',
// base: 'file.txt',
// ext: '.txt',
// name: 'file' } //在 Windows 上:
path.parse('C:\\path\\dir\\file.txt');
// 返回:
// { root: 'C:\\',
// dir: 'C:\\path\\dir',
// base: 'file.txt',
// ext: '.txt',
// name: 'file' }

2.9 path.relative(from,to):

获取from路径到to路径的相对路径的路径字符串。

 //在 POSIX 上:
path.relative('/data/orandea/test/aaa', '/data/orandea/impl/bbb');
// 返回: '../../impl/bbb' //在 Windows 上:
path.relative('C:\\orandea\\test\\aaa', 'C:\\orandea\\impl\\bbb');
// 返回: '..\\..\\impl\\bbb'

2.10 path.resolve([...path]):

将路径片段转换成绝对路径字符串。如果没有传参则返回当前工作路径的绝对路径。

 path.resolve('/foo/bar', './baz');
// 返回: '/foo/bar/baz' path.resolve('/foo/bar', '/tmp/file/');
// 返回: '/tmp/file' path.resolve('wwwroot', 'static_files/png/', '../gif/image.gif');
// 如果当前工作目录是 /home/myself/node,
// 则返回 '/home/myself/node/wwwroot/static_files/gif/image.gif'

3.11 path.toNamespacedPath(path):

path<string>

仅在 Windows 系统上,返回给定 path 的等效名称空间前缀路径。 如果 path 不是字符串,则将返回 path 而不进行修改。

二、Path模块API解析(属性)

3.1 path.delimiter

用来获取当前系统的路径定界符。

console.log(path.delimiter);
// Windows -- 打印:;
// POSIX -- 打印::

可以使用定界符来拆分多个路径组合的字符串:

 console.log(process.env.PATH);
// POSIX -- 打印: '/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin'
// Windows -- // 打印: 'C:\Windows\system32;C:\Windows;C:\Program Files\node\' //使用path.delimiter拆分路径组合字符串
process.env.PATH.split(path.delimiter);
// POSIX -- 返回: ['/usr/bin', '/bin', '/usr/sbin', '/sbin', '/usr/local/bin']
// Windows 返回: ['C:\\Windows\\system32', 'C:\\Windows', 'C:\\Program Files\\node\\']

3.2 path.posix:

用来作为POSIX平台上的path模块方法的特定访问。例如path.basename()方法在POSIX上的可以这样调用:

path.posix.basename('/tmp/myfile.html');
// 返回: 'myfile.html'

3.3 path.sep:

该属性用于获取平台特定的路径片段分隔符。

windows上是 \ 。

POSIX上是 / 。

3.4 path.win32:

用来作为Windows平台上的path模块方法的特定访问。例如path.basename()方法在Windows上可以这样调用:

path.win32.basename('\\tmp\\myfile.html');
// 返回: 'myfile.html'