深入理解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 相关文章推荐
关于JS中的闭包浅谈
Aug 23 Javascript
javascript简单实现命名空间效果
Mar 06 Javascript
如何使用HTML5地理位置定位功能
Apr 27 Javascript
jQuery实现图片文字淡入淡出效果
Dec 21 Javascript
gulp-htmlmin压缩html的gulp插件实例代码
Jun 06 Javascript
ES6中的箭头函数实例详解
Apr 06 Javascript
js仿微信公众平台打标签功能
Apr 08 Javascript
jQuery实现提交表单时不提交隐藏div中input的方法
Oct 08 jQuery
原生js实现随机点名
Jul 05 Javascript
JavaScript实现HTML导航栏下拉菜单
Nov 25 Javascript
js实现圆形菜单选择器
Dec 03 Javascript
解决基于 keep-alive 的后台多级路由缓存问题
Dec 23 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缩放gif和png图透明背景变成黑色的解决方法
2014/10/14 PHP
33道php常见面试题及答案
2015/07/06 PHP
php设计模式之模板模式实例分析【星际争霸游戏案例】
2020/03/24 PHP
关于JavaScript的gzip静态压缩方法
2007/01/05 Javascript
jquery自定义滚动条插件示例分享
2014/02/21 Javascript
jQuery操作基本控件方法实例分析
2015/12/31 Javascript
prototype框架中美元符号$用法分析
2016/01/22 Javascript
Extjs 点击复选框在表格中增加相关信息行
2016/07/12 Javascript
Vue.js中兄弟组件之间互相传值实例
2017/06/01 Javascript
webpack实现热加载自动刷新的方法
2017/07/30 Javascript
vue教程之toast弹框全局调用示例详解
2020/08/24 Javascript
解决vue 引入子组件报错的问题
2018/09/06 Javascript
微信小程序之事件交互操作实例分析
2018/12/03 Javascript
layui 上传图片 返回图片地址的方法
2019/09/26 Javascript
vue.js封装switch开关组件的操作
2020/10/26 Javascript
vant-ui框架的一个bug(解决切换后onload不触发)
2020/11/11 Javascript
vue 实现基础组件的自动化全局注册
2020/12/25 Vue.js
vue3.0中友好使用antdv示例详解
2021/01/05 Vue.js
python实现计算资源图标crc值的方法
2014/10/05 Python
图文详解WinPE下安装Python
2016/05/17 Python
python中redis的安装和使用
2016/12/04 Python
python读取视频流提取视频帧的两种方法
2020/10/22 Python
python用match()函数爬数据方法详解
2019/07/23 Python
python3实现带多张图片、附件的邮件发送
2019/08/10 Python
Python生成词云的实现代码
2020/01/14 Python
mui几种页面跳转方式对比总结概括
2017/08/18 HTML / CSS
家得宝官网:The Home Depot(全球最大的家居装饰专业零售商)
2018/12/17 全球购物
2014年安全生产责任书
2014/07/22 职场文书
市委召开党的群众路线教育实践活动总结大会报告
2014/10/21 职场文书
分居协议书范本(律师见证版)
2014/11/26 职场文书
幼儿园老师新年寄语2015
2014/12/08 职场文书
广告业务员岗位职责
2015/02/13 职场文书
向雷锋同志学习倡议书
2015/04/27 职场文书
Java常用工具类汇总 附示例代码
2021/06/26 Java/Android
详解Spring事件发布与监听机制
2021/06/30 Java/Android
青岛市的收音机研制与生产
2022/04/07 无线电