Node.js Path

Path

稳定性:2 - Stable

path.basename(path[, ext])

  • path 路径
  • ext 可选参数

path.basename()返回路径的最后一部分,请看例子:

path.basename('/foo/bar/baz/asdf/quux.html');
// returns 'quux.html'
path.basename('/foo/bar/baz/asdf/quux.html', '.html');
// returns 'quux'
path.basename('/foo/bar/baz/asdf/quux.html', 'ux.html');
// returns 'qu'

很简单不是吗,通过可选参数ext我们还可以对返回值进行自定义截取,但请注意,该方法所有的参数必须是字符串,否则会报错。

path.dirname(path)

  • path 路径

path.dirname()返回path的所在路径。

path.dirname('/foo/bar/baz/asdf');
// returns '/foo/bar/baz'
path.dirname('/foo/bar/baz/asdf/quux.html');
// returns '/foo/bar/baz/asdf'
path.dirname('quux.html');
// returns '.'

path.extname(path)

  • path

返回路径最后一部分中的最后一个.字符到结尾截取的字符串,如果没有字符.,或者路径最后一部分的开头是字符.,则会返回空字符串。

path.extname('index.html')
// returns '.html'
path.extname('index.coffee.md')
// returns '.md'
path.extname('index.')
// returns '.'
path.extname('index')
// returns ''
path.extname('.index')
// returns ''

path.normalize(path)

-path

使字符串路径标准化,如果有多个'/',则标准化后会变成一个'/';如果结尾有'/',则该斜线会被保留;如果是windows环境,则'/'会被标准化为'\\\\'

path.normalize('/foo/bar///baz/asdf/quux/../');
    // return '/foo/bar/baz/asdf/' posix
    // return '\\foo\\bar\\baz\\asdf\\' windows
path.normalize('');
    // return '.'

path.join([path1][, path2][, ...])

  • pathX

把所有字符串参数合到一起并返回标准化后的路径

path.join('/foo/', 'bar', 'baz//asdf', 'quux', '..', 'test.html')
    // return '/foo/bar/baz/asdf/test.html'
path.join('/foo', '', 'test.html')
    // return '/foo/test.html'  如果有空字符串参数,则会被忽略
path.join('')
    // return '.'  如果所有参数合到一起是空字符串,则会返回'.',表示当前目录

path.isAbsolute(path)

  • path

判断path是否是绝对路径

// Posix
path.isAbsolute('/foo/bar') // true
path.isAbsolute('/baz/..')  // true
path.isAbsolute('qux/')     // false
path.isAbsolute('.')        // false

// Windows
path.isAbsolute('//server')  // true
path.isAbsolute('C:/foo/..') // true
path.isAbsolute('bar\\baz')  // false
path.isAbsolute('.')         // false

path.format(pathObject)

根据参数pathObject返回路径字符串。
Posix例子:

// If `dir` and `base` are provided, `dir` + platform separator + `base`
// will be returned.
path.format({
    dir: '/home/user/dir',
    base: 'file.txt'
});
// returns '/home/user/dir/file.txt'

// `root` will be used if `dir` is not specified.
// `name` + `ext` will be used if `base` is not specified.
// If only `root` is provided or `dir` is equal to `root` then the
// platform separator will not be included.
path.format({
    root: '/',
    base: 'file.txt'
});
// returns '/file.txt'

path.format({
    dir: '/',
    root: '/',
    name: 'file',
    ext: '.txt'
});
// returns '/file.txt'

// `base` will be returned if `dir` or `root` are not provided.
path.format({
    base: 'file.txt'
});
// returns 'file.txt'

Windows例子:

path.format({
    root : "C:\\",
    dir : "C:\\path\\dir",
    base : "file.txt",
    ext : ".txt",
    name : "file"
})
// returns 'C:\\path\\dir\\file.txt'

path.parse(pathString)

该方法跟path.format的功能“相反”,根据pathString返回对应的对象。
Posix例子:

path.parse('/home/user/dir/file.txt')
// returns
// {
//    root : "/",
//    dir : "/home/user/dir",
//    base : "file.txt",
//    ext : ".txt",
//    name : "file"
// }

Windows例子:

path.parse('C:\\path\\dir\\index.html')
// returns
// {
//    root : "C:\\",
//    dir : "C:\\path\\dir",
//    base : "index.html",
//    ext : ".html",
//    name : "index"
// }

path.delimiter

表示操作系统有关路径的分隔符,;:
Posix的例子:

console.log(process.env.PATH)
// '/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin'

process.env.PATH.split(path.delimiter)
// returns ['/usr/bin', '/bin', '/usr/sbin', '/sbin', '/usr/local/bin']

Windows的例子:

console.log(process.env.PATH)
// 'C:\Windows\system32;C:\Windows;C:\Program Files\node\'

process.env.PATH.split(path.delimiter)
// returns ['C:\\Windows\\system32', 'C:\\Windows', 'C:\\Program Files\\node\\']

path.sep

表示操作系统有关文件的分隔符,不要跟上一个弄混淆了哦,'/''\\\\'
Posix的例子:

'foo/bar/baz'.split(path.sep)
// returns ['foo', 'bar', 'baz']

Windows的例子:

'foo\\bar\\baz'.split(path.sep)
// returns ['foo', 'bar', 'baz']

path.relative(from, to)

该方法根据两个绝对路径fromto解析出一个相对路径(说白了就是从一个绝对路径到另一个绝对路径是怎么走的)

path.relative('C:\\orandea\\test\\aaa', 'C:\\orandea\\impl\\bbb')
// returns '..\\..\\impl\\bbb'

path.relative('/data/orandea/test/aaa', '/data/orandea/impl/bbb')
// returns '../../impl/bbb'

path.relative('', 'C:\\orandea\\impl\\bbb')
// 如果有参数是空字符串,则会返回当前的工作路径,如当前路径是'C:\\user\\pazi\\Desktop',Returns '..\\..\\..\\orandea\\impl\\bbb'

path.relative('', '')
// returns ''

path.resolve([from ...], to)

简单讲就是执行一连串的cd命令,执行后返回一个绝对路径, 例如:

path.resolve('foo/bar', '/tmp/file/', '..', 'a/../subfile')

类似于:

cd foo/bar
cd /tmp/file/
cd ..
cd a/../subfile
pwd

还有一些例子供大家参考:

path.resolve('/foo/bar', './baz')
// returns '/foo/bar/baz'

path.resolve('/foo/bar', '/tmp/file/')
// returns '/tmp/file'

path.resolve('wwwroot', 'static_files/png/', '../gif/image.gif')
// if currently in /home/myself/node, it returns
// '/home/myself/node/wwwroot/static_files/gif/image.gif'

path.resolve('wwwroot', '', '../gif/image.gif')
// if currently in /home/myself/node, it returns
// '/home/myself/node/gif/image.gif'
// 注意第二个参数是空字符串,则会被替换成当前的工作路径/home/myself/node/wwwroot,而不是/homde/myself/node

path.win32和path.posix

这两个对象提供了上述的全部方法,但不推荐使用,有可能会产生一些奇怪的结果,如果读者想研究的话,请阅读path模块的源码。

最后,请注意本文中所有方法的参数必须是字符串格式,否则一些方法会认定此参数无效或直接报错,造成不必要的麻烦。

本文是根据node.js目前稳定版本的文档Node.js v4.4.4 Documentation进行总结的,如您在阅读的过程中发现问题,请联系作者,最后感谢您的支持!

作者 小菜荔枝 转载请联系作者获得授权

你可能感兴趣的:(Node.js Path)