深入理解node.js之path模块


Posted in Javascript onMay 03, 2017

node之path模块

//引用该模块
var path = require("path");

1、路径解析,得到规范化的路径格式

//对window系统,目录分隔为'\', 对于UNIX系统,分隔符为'/',针对'..'返回上一级;/与\\都被统一转换
//path.normalize(p);

var myPath = path.normalize(__dirname + '/test/a//b//../c/utilyou.mp3');
console.log(myPath); //windows: E:\workspace\NodeJS\app\fs\test\a\c\utilyou.mp3

2、路径结合、合并,路径最后不会带目录分隔符

//path.join([path1],[path2]..[pathn]);
/**
 * [path1] 路径或表示目录的字符,
 */

var path1 = 'path1',
  path2 = 'path2//pp\\',
  path3 = '../path3';

var myPath = path.join(path1, path2, path3);
console.log(myPath); //path1\path2\path3

3、获取绝对路径

//path.resolve(path1, [path2]..[pathn]);

//以应用程序为起点,根据参数字符串解析出一个绝对路径

/**
 * path 必须至少一个路径字符串值
 * [pathn] 可选路径字符串
 */

var myPath = path.resolve('path1', 'path2', 'a/b\\c/');
console.log(myPath);//E:\workspace\NodeJS\path1\path2\a\b\c

4、获取相对路径

//path.relative(from, to);
//获取两路径之间的相对关系

/**
 * from 当前路径,并且方法返回值是基于from指定到to的相对路径
 * to  到哪路径,
 */

var from = 'c:\\from\\a\\',
  to = 'c:/test/b';

var _path = path.relative(from, to);
console.log(_path); //..\..\test\b; 表示从from到to的相对路径

5、path.dirname(p)

// 获取路径中目录名

var myPath = path.dirname(__dirname + '/test/util you.mp3');
console.log(myPath);

6、path.basename(path, [ext])

// 获取路径中文件名,后缀是可选的,如果加,请使用'.ext'方式来匹配,则返回值中不包括后缀名;

var myPath = path.basename(__dirname + '/test/util you.mp3', '.mp3');
console.log(myPath);

7、path.extname(path)   //获取路径中的扩展名,如果没有'.',则返回空

8、path.sep属性   //返回操作系统中文件分隔符; window是'\\', Unix是'/'

9、path.delimiter属性   //返回操作系统中目录分隔符,如window是';', Unix中是':'

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
基于jquery的关于动态创建DOM元素的问题
Dec 24 Javascript
解决Extjs上传图片无法预览的解决方法
Mar 22 Javascript
jQuery 借助插件Lavalamp实现导航条动态美化效果
Sep 27 Javascript
jQuery动态加载css文件实现方法
Jun 15 Javascript
解决Window10系统下Node安装报错的问题分析
Dec 13 Javascript
js数组去重的hash方法
Dec 22 Javascript
JS中type="button"和type="submit"的区别
Jul 04 Javascript
webpack多入口多出口的实现方法
Aug 17 Javascript
记React connect的几种写法(小结)
Sep 18 Javascript
详解React服务端渲染从入门到精通
Mar 28 Javascript
layui 上传文件_批量导入数据UI的方法
Sep 23 Javascript
详解vue-template-admin三级路由无法缓存的解决方案
Mar 10 Javascript
判断颜色是否合法的正则表达式(详解)
May 03 #Javascript
Vue input控件通过value绑定动态属性及修饰符的方法
May 03 #Javascript
ES6中参数的默认值语法介绍
May 03 #Javascript
Express之get,pos请求参数的获取
May 02 #Javascript
利用prop-types第三方库对组件的props中的变量进行类型检测
May 02 #Javascript
xmlplus组件设计系列之路由(ViewStack)(7)
May 02 #Javascript
JavaScript比较两个数组的内容是否相同(推荐)
May 02 #Javascript
You might like
PHP 组件化编程技巧
2009/06/06 PHP
ThinkPHP独立分组使用的注意事项
2014/11/25 PHP
PHP获取真实客户端的真实IP
2017/03/07 PHP
PHP数组式访问接口ArrayAccess用法分析
2017/12/28 PHP
php字符串截取函数mb_substr用法实例分析
2019/06/25 PHP
Extjs Ajax 乱码问题解决方案
2009/04/15 Javascript
return false,对阻止事件默认动作的一些测试代码
2010/11/17 Javascript
JavaScript面向对象知识串结(读JavaScript高级程序设计(第三版))
2012/07/17 Javascript
select标记美化--JS式插件、后期加载
2013/04/01 Javascript
js 固定悬浮效果实现思路代码
2013/08/02 Javascript
js实现文本框中焦点在最后位置
2014/03/04 Javascript
javascript 控制input只允许输入的各种指定内容
2014/06/19 Javascript
JavaScript中的闭包(Closure)详细介绍
2014/12/30 Javascript
解决Jquery向页面append新元素之后事件的绑定问题
2015/03/16 Javascript
Node.js 异步编程之 Callback介绍(一)
2015/03/30 Javascript
使用javascript插入样式
2016/03/14 Javascript
微信小程序 navigation API实例详解
2016/10/02 Javascript
AngularJS指令与控制器之间的交互功能示例
2016/12/14 Javascript
js点击时关闭该范围下拉菜单之外的菜单方法
2018/01/11 Javascript
vue axios整合使用全攻略
2018/05/24 Javascript
Python中使用动态变量名的方法
2014/05/06 Python
简析Python的闭包和装饰器
2016/02/26 Python
pymysql的简单封装代码实例
2020/01/08 Python
给keras层命名,并提取中间层输出值,保存到文档的实例
2020/05/23 Python
Scrapy基于scrapy_redis实现分布式爬虫部署的示例
2020/09/29 Python
python语言time库和datetime库基本使用详解
2020/12/25 Python
CSS3中Animation动画属性用法详解
2016/07/04 HTML / CSS
老师给学生的表扬信
2014/01/17 职场文书
行政部工作岗位职责范本
2014/03/05 职场文书
委托书样本
2014/04/02 职场文书
提拔干部考察材料
2014/05/26 职场文书
五一劳动节演讲稿
2014/09/12 职场文书
诉讼授权委托书
2014/10/15 职场文书
初中语文教师研修日志
2015/11/13 职场文书
Python Matplotlib绘制条形图的全过程
2021/10/24 Python
springboot新建项目pom.xml文件第一行报错的解决
2022/01/18 Java/Android