Node.js 提供了一些处理 文件/文件夹 路径的公用方法,能够这样引入:html
var path = require('path');
path.basename(path[, ext]) ---> 返回值:Stringnode
path.basename() 方法返回路径的最后一部分,与 Unix 的 basename 命令类似api
参数:ide
path:String工具
ext:String,可选的文件拓展名,若是提供了ext 参数,则返回值中不包括拓展名
ui
当 path 不是一个字符串或者提供了ext 但不是字符串时,会报错 TypeError
this
path.basename('/foo/bar/baz/asdf/quux.html') // Returns: 'quux.html' path.basename('/foo/bar/baz/asdf/quux.html', '.html') // Returns: 'quux'
path.dirname(path) ---> 返回值:Stringspa
path.dirname() 方法返回的是路径的目录名,与 Unix 中的 dirname 类似操作系统
参数:命令行
path:String
若是 path 不是字符串,将会抛出 TypeError
错误
path.dirname('/foo/bar/baz/asdf/quux') // Returns: '/foo/bar/baz/asdf'
path.extname(path) ---> 返回值:String
path.extname() 方法返回的是路径的拓展名,从路径中的最后一个“.”到最后一个字符,若是最后一部分没有“.”,或者路径中 basename的第一个字符是“.”,那么,将返回一个空字符串
参数:
path:String
若是 path 不是字符串,将会抛出 TypeError
错误
例如:
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.format(pathObject) ---> 返回值:String
path.format() 方法从对象中返回一个路径的字符串,与 path.parse()
相反
参数:
pathObject :Object
dir :String
root :String
base :String
name :String
ext :String
例如:
path.format({ root : "C:\\", dir : "C:\\path\\dir", base : "file.txt", ext : ".txt", name : "file" }); // Returns: 'C:\\path\\dir\\file.txt'
path.isAbsolute(path) ---> 返回值:Boolean
path.isAbsolute() 方法用来判断 path 是否是绝对路径
参数:
path:String
若是给出的 path 是一个 0 长度的字符串,将返回 false;若是 path 不是一个字符串,将会抛出 TypeError
错误
例如:Windows 系统
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
path.join([...paths]) ---> 返回值:String
path.join() 方法将 path 片断按照操做系统系统特定的分隔符链接在一块儿,而后将路径结果规范化。
0 长度 path 的片断将被忽略,若是链接的路径是 0 长度的字符串,将返回一个“.”来表明当前的工做目录
若是任意一个 path片断不是字符串,将会抛出 TypeError
错误
例如:
path.join('/foo', 'bar', 'baz/asdf', 'quux', '..') // Returns: '/foo/bar/baz/asdf' path.join('foo', {}, 'bar') // throws TypeError: Arguments to path.join must be strings
path.normalize(path) ---> 返回值:String
path.normalize() 方法用于把 path 规范化,解析出 '..' 和 '.'片断
当发现多个连续地单独路径字符片断(例如:Unix 系统中的 / 和 Windows 系统中的 \),它们将被各自操做系统的 单个 分隔符替代
参数:
path:String
若是 path 是一个 0 长度的字符串,将返回一个“.”来表明当前的工做目录;若是 path 不是一个字符串,将会抛出 TypeError
错误
例如:Unix 系统
path.normalize('/foo/bar//baz/asdf/quux/..') // Returns: '/foo/bar/baz/asdf'
Windows 系统
path.normalize('C:\\temp\\\\foo\\bar\\..\\'); // Returns: 'C:\\temp\\foo\\'
path.parse(path) ---> 返回值:Object
path.parse() 方法返回路径字符串的对象
返回的对象将包含如下属性:
dir :String
root :String
base :String
name :String
ext :String
参数:
path:String
若是 path 不是字符串,将会抛出 TypeError
错误
例如:Windows 系统
path.parse('C:\\path\\dir\\file.txt') // Returns: // { // root : "C:\\", // dir : "C:\\path\\dir", // base : "file.txt", // ext : ".txt", // name : "file" // }
path.relative(from, to) ---> 返回值:String
path.relative() 方法返回从 from 到 to 之间的相对路径,若是两者是相同的路径,则返回一个 0 长度的字符串
from 当前路径,而且方法返回值是基于 from 指定到 to 的相对路径
to 到哪一个路径
from 和 to 任意一个不是字符串的话,将会抛出 TypeError
错误
例如:Windows 系统
path.relative('C:\\orandea\\test\\aaa', 'C:\\orandea\\impl\\bbb') // Returns: '..\\..\\impl\\bbb'
path.resolve([...paths]) ---> 返回值:String
path.resolve() 方法将一个路径序列或路径片断解析成 绝对路径
提供的路径片断从右往左处理,后面的路径会优先处理直到构造出一个绝对路径。例如,给出一个路径片断 /foo
, /bar
, baz
,调用 path.resolve('/foo', '/bar', 'baz') 会返回 /bar/baz
若是处理全部的路径片断都不能生成一个绝对路径,那么,表示当前的工做目录已经被使用了
路径的结果都是规范化的并且没有斜杠,除非路径被解析成根目录
0 长度的 path 片断将被忽略,若是没有 path 片断经过,path.resolve() 将返回当前工做目录的绝对路径
若是任意一个参数不是字符串的话,将会抛出 TypeError
错误
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/p_w_picpath.gif') // if the current working directory is /home/myself/node, // this returns '/home/myself/node/wwwroot/static_files/gif/p_w_picpath.gif'
path.delimiter ---> 类型:String
path.delimiter 提供特定平台的路径分隔符
;
---> Windows 系统
:
---> Unix 系统
例如:Unix 系统中
console.log(process.env.PATH) // Prints: '/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) // Prints: '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 ---> 类型:String
返回操做系统中文件分隔符; window ---> \\ , Unix ---> /
例如:Unix 系统
'foo/bar/baz'.split(path.sep) // Returns: ['foo', 'bar', 'baz']
Windows 系统
'foo\\bar\\baz'.split(path.sep) // Returns: ['foo', 'bar', 'baz']
新建一个JS 文件:
var path = require("path"); // 格式化路径 console.log('normalization : ' + path.normalize('/test/test1//2slashes/1slash/tab/..')); // 链接路径 console.log('joint path : ' + path.join('/test', 'test1', '2slashes/1slash', 'tab', '..')); // 转换为绝对路径 console.log('resolve : ' + path.resolve('main.js')); // 路径中文件的后缀名 console.log('ext name : ' + path.extname('main.js'));
在命令行工具中运行,查看输出结果: