IO.js Path

2018-11-28 22:34 更新

穩(wěn)定度: 2 - 穩(wěn)定

這個(gè)模塊提供了處理和轉(zhuǎn)換文件路徑的工具。幾乎所有的方法都僅提供字符串轉(zhuǎn)換功能。文件系統(tǒng)不會(huì)去檢查路徑是否可用。

通過require('path')來使用這個(gè)模塊。以下是提供的方法:

path.normalize(p)

規(guī)范化字符串路徑,注意'..''.'部分。

當(dāng)有多個(gè)連續(xù)斜杠時(shí),它們會(huì)被替換為一個(gè)斜杠;當(dāng)路徑的最后有一個(gè)斜杠,它會(huì)被保留。在Windows下使用反斜杠。

例子:

path.normalize('/foo/bar//baz/asdf/quux/..')
// returns
'/foo/bar/baz/asdf'

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

連接所有的參數(shù),并且規(guī)范化結(jié)果路徑。

參數(shù)必須是字符串。在0.8版本中,非字符串參數(shù)會(huì)被忽略,在0.10版本及之后,會(huì)拋出一個(gè)異常。

例子:

path.join('/foo', 'bar', 'baz/asdf', 'quux', '..')
// returns
'/foo/bar/baz/asdf'

path.join('foo', {}, 'bar')
// throws exception
TypeError: Arguments to path.join must be strings

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

to解析為絕對路徑。

如果to不已經(jīng)是相對于from參數(shù)的絕對路徑,to會(huì)被添加到from的右邊,直到找出絕對了路徑。如果使用了from中所有的路徑仍沒有找出絕對路徑,當(dāng)前的工作路徑也會(huì)被使用。結(jié)果路徑會(huì)被規(guī)范化,并且結(jié)尾的斜杠會(huì)被移除,除非解析得到了一個(gè)根路徑。非字符串參數(shù)會(huì)被忽略。

另一個(gè)思路是將它看做shell中一系列的cd命令:

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

相似于:

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

區(qū)別是不同的路徑不需要一定存在,并且可以是文件。

例子:

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/iojs, it returns
'/home/myself/iojs/wwwroot/static_files/gif/image.gif'

path.isAbsolute(path)

判斷path是否是一個(gè)絕對路徑。一個(gè)絕對路徑總是被解析為相同的路徑,無論當(dāng)前工作目錄是哪里。

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.relative(from, to)

解析從fromto的相對路徑。

當(dāng)我們有兩個(gè)絕對路徑,并且我們要得到它們間一個(gè)對于另外一個(gè)的相對路徑。這實(shí)際上是path.resolve的相反操作。我們可以看看這是什么意思:

path.resolve(from, path.relative(from, to)) == path.resolve(to)

例子:

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.dirname(p)

返回路徑的目錄名。與Unix dirname 命令相似。

例子:

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

path.basename(p[, ext])

返回路徑中的最后一部分。與Unix basename 命令相似。

例子:

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

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

path.extname(p)

返回路徑的擴(kuò)展名,即從路徑的最后一部分中的最后一個(gè)'.'到末尾之間的字符串。如果路徑的最后一部分沒有'.',或者第一個(gè)字符是'.',那么將返回一個(gè)空字符串,例子:

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

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

path.extname('index.')
// returns
'.'

path.extname('index')
// returns
''

path.sep

返回特定平臺(tái)的文件分隔符。'\\''/'。

一個(gè)*nix上的例子:

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

一個(gè)Windows上的例子:

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

path.delimiter

特定平臺(tái)的路徑分隔符,';'':'。

一個(gè)*nix上的例子:

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']

一個(gè)Windows上的例子:

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

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

path.parse(pathString)

根據(jù)一個(gè)路徑字符串返回一個(gè)對象。

一個(gè)*nix上的例子:

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

一個(gè)Windows上的例子:

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

path.format(pathObject)

根據(jù)一個(gè)對象,返回一個(gè)路徑字符串,與path.parse相反。

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

path.posix

提供對上述的路徑方法的訪問,但是總是以兼容posix的方式交互(interact)。

path.win32

提供對上述的路徑方法的訪問,但是總是以兼容win32的方式交互(interact)。

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號