热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

nodejs入门API之path模块

Path模块在各个系统上的差异Path模块API解析 一、Path模块在各个系统上的差异path模块提供用于处理文件路径和目录路径的使用工具。letpathrequire(path
  • 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:路径字符

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

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)

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

1 //示例一
2 path.dirname('/foo/bar/baz/asdf/quux');
3 // 返回: '/foo/bar/baz/asdf'
4 
5 //示例二
6 path.dirname("/foo/path/index.js");
7 // 返回: '/foo/path'

3.3 path.extname(path)

用来获取路径扩展名。

 1 path.extname('index.html');
 2 // 返回: '.html'
 3 path.extname('index.coffee.md');
 4 // 返回: '.md'
 5 path.extname('index.');
 6 // 返回: '.'
 7 path.extname('index');
 8 // 返回: ''
 9 path.extname('.index');
10 // 返回: ''
11 path.extname('.index.md');
12 // 返回: '.md'

2.4 path.format(pathObject)

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

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

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

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

2.5 path.isAbsolute(path):

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

 1 //windows上的示例
 2 let path = require("path");
 3 path.isAbsolute('//server');    // true
 4 path.isAbsolute('\\\\server');  // true
 5 path.isAbsolute('C:/foo/..');   // true
 6 path.isAbsolute('C:\\foo\\..'); // true
 7 path.isAbsolute('bar\\baz');    // false
 8 path.isAbsolute('bar/baz');     // false
 9 path.isAbsolute('.');           // false
10 
11 //POSIX
12 path.isAbsolute('/foo/bar'); // true
13 path.isAbsolute('/baz/..');  // true
14 path.isAbsolute('qux/');     // false
15 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()处理转换成标准的符合规范的路径字符串,比如示例:

 1 //例如,在 POSIX 上:
 2 path.normalize('/foo/bar//baz/asdf/quux/..');
 3 // 返回: '/foo/bar/baz/asdf'
 4 
 5 //在 Windows 上:
 6 path.normalize('C:\\temp\\\\foo\\bar\\..\\');
 7 // 返回: 'C:\\temp\\foo\\'
 8 
 9 path.win32.normalize('C:////temp\\\\/\\/\\/foo/bar');
10 // 返回: 'C:\\temp\\foo\\bar'

2.8 path.parse(path):

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

 1 //在 POSIX 上:
 2 path.parse('/home/user/dir/file.txt');
 3 // 返回:
 4 // { root: '/',
 5 //   dir: '/home/user/dir',
 6 //   base: 'file.txt',
 7 //   ext: '.txt',
 8 //   name: 'file' }
 9 
10 //在 Windows 上:
11 path.parse('C:\\path\\dir\\file.txt');
12 // 返回:
13 // { root: 'C:\\',
14 //   dir: 'C:\\path\\dir',
15 //   base: 'file.txt',
16 //   ext: '.txt',
17 //   name: 'file' }

2.9 path.relative(from,to):

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

1 //在 POSIX 上:
2 path.relative('/data/orandea/test/aaa', '/data/orandea/impl/bbb');
3 // 返回: '../../impl/bbb'
4 
5 //在 Windows 上:
6 path.relative('C:\\orandea\\test\\aaa', 'C:\\orandea\\impl\\bbb');
7 // 返回: '..\\..\\impl\\bbb'

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

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

1 path.resolve('/foo/bar', './baz');
2 // 返回: '/foo/bar/baz'
3 
4 path.resolve('/foo/bar', '/tmp/file/');
5 // 返回: '/tmp/file'
6 
7 path.resolve('wwwroot', 'static_files/png/', '../gif/image.gif');
8 // 如果当前工作目录是 /home/myself/node,
9 // 则返回 '/home/myself/node/wwwroot/static_files/gif/image.gif'

3.11 path.toNamespacedPath(path):

 path

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

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

3.1 path.delimiter

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

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

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

1 console.log(process.env.PATH);
2 // POSIX -- 打印: '/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin'
3 // Windows -- // 打印: 'C:\Windows\system32;C:\Windows;C:\Program Files\node\'
4 
5 //使用path.delimiter拆分路径组合字符串
6 process.env.PATH.split(path.delimiter);
7 // POSIX -- 返回: ['/usr/bin', '/bin', '/usr/sbin', '/sbin', '/usr/local/bin']
8 // 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'

推荐阅读
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 本文介绍了如何在 Node.js 中使用 `setDefaultEncoding` 方法为可写流设置默认编码,并提供了详细的语法说明和示例代码。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 本文探讨了Web开发与游戏开发之间的主要区别,旨在帮助开发者更好地理解两种开发领域的特性和需求。文章基于作者的实际经验和网络资料整理而成。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 本文介绍了如何在C#中启动一个应用程序,并通过枚举窗口来获取其主窗口句柄。当使用Process类启动程序时,我们通常只能获得进程的句柄,而主窗口句柄可能为0。因此,我们需要使用API函数和回调机制来准确获取主窗口句柄。 ... [详细]
  • VPX611是北京青翼科技推出的一款采用6U VPX架构的高性能数据存储板。该板卡搭载两片Xilinx Kintex-7系列FPGA作为主控单元,内置RAID控制器,支持多达8个mSATA盘,最大存储容量可达8TB,持续写入带宽高达3.2GB/s。 ... [详细]
  • 本文介绍如何在PostgreSQL数据库中正确插入和处理JSON数据类型,确保数据完整性和避免常见错误。 ... [详细]
author-avatar
62755
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有