模块方法概览

  • Path

    • path.basename(p[, ext])
    • path.delimiter
    • path.dirname(p)
    • path.extname(p)
    • path.format(pathObject)
    • path.isAbsolute(path)
    • path.join([path1][, path2][, ...])
    • path.normalize(p)
    • path.parse(pathString)
    • path.posix
    • path.relative(from, to)
    • path.resolve([from ...], to)
    • path.sep
    • path.win32

Path模块

这个模块包含传递和转换文件路径的公共程序。几乎所有的方法只会在字符串转化的时候执行。 文件系统不会尝试去确认路径是否合法。

通过 require('path')来使用这个模块。 以下是该模块提供的方法:

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.delimiter

平台特定的路径分隔符, ';'或者 ':' 。

在UNIX或者LINUX系统下的一个例子:

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

译者多嘴一句:不要把精力过多的放在细节上,如果你不太明白某个属性或方法是怎么回事,don't worry,一切都会随着时间而变得好起来。

path.dirname(p)

返回一个路径所对应的文件夹名。就像你在Unix下使用dirname命令那样。

例子:

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

path.extname(p)

返回路径的扩展名,从最后一个'.'字符到路径最后一个部分的字符串的结尾。如果在路径的最后一部分中没有'.'字符或者以'.'字符开头,那么则会返回一个空字符串。

例子:

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)

从一个对象中返回一个路径字符串, 与之相对应的方法请参考path.parse。

例子:

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

path.isAbsolute(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

注意: 如果被当作参数传递的路径字符串是一个长度为0的字符串,与path模块下其他的方法不同,他会按照原样使用并返回false。

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

把所有的参数结合在一起并标准化。

参数必须是字符串。在v0.8下,不是字符串的参数会被忽略.在v0.10或更高版本,会抛出一个异常。

例子:

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

Note: join方法的参数中如果有长度为0的字符串,与path模块下其他的函数不同,这些参数将会被忽略。如果没有给join方法传递任何参数那么会返回'.', 代表目前的工作目录。

path.normalize(p)

标准化一个路径字符串, 特别是'..'和'.'的部分。

当发现多个斜杠时,他们将会替换成一个单斜杠; 当一个路径结尾有一个斜杠,它将会被保留。在windows下会使用反斜线。

例子:

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

注意: 如果将一个空字符串当作参数传递那么会返回一个'.',代表当前的工作目录。

path.parse(pathString)

将一个路径字符串当作对象返回。

在UNIX或LINUX下的例子:

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.posix

提供一个访问path前缀的方法但是一般会由于posix兼容方式二相互影响。(译者水平有限,这句翻译不准)

path.relative(from, to)

有时候我们有两个绝对路径, 我们需要从一个路径向另外一个路径派生他们之间有关系的路径。 这个方法实际上是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'

提示:如果relative方法的的参数是空字符串那么当前的工作目录会去替代那个空字符串。如果提供了两个相同的参数,那么该方法会返回一个空字符串。

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

将 to 分解成一个绝对路径。

如果 to 不是一个绝对路径那么from将会被优先考虑, 直到找到一个绝对路径。如果用完了所有的from依然没有找到绝对路径,就会使用当前的工作目录。结果路径会被标准化, 尾部斜杠会被移除除非路径分解到根目录。from如果有空字符串将会被忽略。

如果不太理解,可以试着将其看成cmd中的一系列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.sep

平台特定的文件分隔符。 '\\' 或者 '/'。

LINUX或UNIX下的例子:

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

windows下的例子:

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

path.win32

提供访问path前缀的方法但是会在win32的兼容方式下相互影响。

nodejs 5.2.0文档自翻译——Path模块的更多相关文章

  1. nodejs 5.2.0文档自翻译——HTTP模块

    HTTP Class: http.Agent new Agent([options]) agent.destroy() agent.freeSockets agent.getName(options) ...

  2. Umbraco官方技术文档 中文翻译

    Umbraco 官方技术文档中文翻译 http://blog.csdn.net/u014183619/article/details/51919973 http://www.cnblogs.com/m ...

  3. vue mand-mobile按2.0文档默认安装的是1.6.8版本

    vue mand-mobile按2.0文档默认安装的是1.6.8版本 npm list mand-mobilebigbullmobile@1.0.0 E:\webcode\bigbullmobile` ...

  4. Beautiful Soup 4.2.0 文档

    Beautiful Soup 4.2.0 文档 Beautiful Soup 是一个可以从HTML或XML文件中提取数据的Python库.它能够通过你喜欢的转换器实现惯用的文档导航,查找,修改文档的方 ...

  5. css2.0文档查阅及字体样式

    css2.0文档查阅下载     网址:http://soft.hao123.com/soft/appid/9517.html <html xmlns="http://www.w3.o ...

  6. DecimalFormat 中的 # 与 0 的区别(中文帮助文档中翻译可能是错误的)

    想对数字进行格式化的时候,可能会使用到 java.text.DecimalFormat 类.中文帮助文档中,有如下符号 位置 本地化 含义 0 数字 是 阿拉伯数字 # 数字 是 阿拉伯数字,如果不存 ...

  7. LTE 测试文档(翻译)

    Testing Documentation 翻译 (如有不当的地方,欢迎指正!)     1 概述   为了测试和验证 ns-3 LTE 模块,文档提供了几个 test suites (集成在 ns- ...

  8. PHP经验——PHPDoc PHP注释的标准文档(翻译自Wiki)

    文档注释,无非“//”和“/**/”两种 ,自己写代码,就那么点,适当写几句就好了:但是一个人总有融入团队的一天,团队的交流不是那几句注释和一张嘴能解决的,还需要通用的注释标准. PHPDoc是PHP ...

  9. Nodejs v4.x.0API文档学习(2)Assert断言测试模块

    文档参考地址:https://nodejs.org/dist/latest-v4.x/docs/api/ Assert(断言) assert模块提供了一组简单的断言测试方法,可以拥有测试不变量.该模块 ...

随机推荐

  1. 2014--9=17 软工二班 MyEclipse blue==修改浏览器语言

  2. 转TerreyLee AJAX入门系列2——ScriptManager的理解总结

    ScriptManager的功能之一就是处理页面上局部更新,对于这点,我想大家都知道.但是他工作的原理到底是什么呢,这个暂且不从正面来回答. 我们这样想一下,目前能够真正实现局部刷新的就是js+xml ...

  3. eclipse(STS,myeclipse)老是报ThreadPoolExecutor$Worker.run()

    资料地址:http://stackoverflow.com/questions/6290470/eclipse-debugger-always-blocks-on-threadpoolexecutor ...

  4. Hibernate检索方式 分类: SSH框架 2015-07-10 22:10 4人阅读 评论(0) 收藏

    我们在项目应用中对数据进行最多的操作就是查询,数据的查询在所有ORM框架中也占有极其重要的地位.那么,如何利用Hibernate查询数据呢?Hibernate为我们提供了多种数据查询的方式,又称为Hi ...

  5. java 菱形

    //画菱形 一半 for(int hs=1;hs<11;hs++) //行数 { //画空格 for(int kg = 9; kg >= hs; kg--) //空格数 { System. ...

  6. js 中 typeof 的使用

    js中的变量是松散类型(即弱类型)的,可以用来保存任何类型的数据. typeof 可以用来检测给定变量的数据类型,可能的返回值: 'undefined' --- 这个值未定义 'boolean' -- ...

  7. svn is already under version control问题解决

    svn ci 时出现 xx is already under version control,然后无法提交,出现这个问题的原因是你所提交的文件或目录是其他SVN的东西,即下面有.svn的目录,需要先把 ...

  8. bzoj2085

    首先看到k的范围就该知道这题不是倍增就是矩乘 首先肯定要求出任意一对串(a,b) a的后缀与b的前缀相同的最长长度是多少 考虑到kmp求出的失配指针是一个串最长后缀和前缀相等的长度 这里多个串我们只要 ...

  9. iOS开发:记录开发中遇到的编译或运行异常以及解决方案

    1.部署到真机异常 dyld`dyld_fatal_error: ->  0x120015088 <+0>: brk    #0x3 dyld: Library not loaded ...

  10. ZOJ 2587 Unique Attack (最小割唯一性)

    题意 判断一个无向图的割是否唯一 思路 错误思路:一开始想的是判断割边是否都是关键割边,那既然割边两端点能连通S.T点的边是关键边,那么只要遇到有某个边两端点不连通S or T则这条边就不是关键割边( ...