深入理解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 获取表单text,areatext,radio,checkbox,select值的代码
Nov 12 Javascript
JavaScript高级程序设计 扩展--关于动态原型
Nov 09 Javascript
jquery中的$(document).ready()使用小结
Feb 14 Javascript
jquery使整个div区域可以点击的方法
Jun 24 Javascript
AngularJS基础 ng-src 指令简单示例
Aug 03 Javascript
js实现年月日表单三级联动
Apr 17 Javascript
浅谈Angular2 ng-content 指令在组件中嵌入内容
Aug 18 Javascript
angular2系列之路由转场动画的示例代码
Nov 09 Javascript
使用async、enterproxy控制并发数量的方法详解
Jan 02 Javascript
vue-router的HTML5 History 模式设置
Sep 08 Javascript
微信小程序select下拉框实现源码
Nov 08 Javascript
Ant Design moment对象和字符串之间的相互转化教程
Oct 27 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
sourcesafe管理phpproj文件的补充说明(downmoon)
2009/04/11 PHP
浅谈Eclipse PDT调试PHP程序
2014/06/09 PHP
ThinkPHP CURD方法之limit方法详解
2014/06/18 PHP
php自定义apk安装包实例
2014/10/20 PHP
PHP socket 模拟POST 请求实例代码
2016/07/18 PHP
关于Yii2框架跑脚本时内存泄漏问题的分析与解决
2019/12/01 PHP
用正则xmlHttp实现的偷(转)
2007/01/22 Javascript
js读取并解析JSON类型数据的方法
2015/11/14 Javascript
AngularJS实现标签页的两种方式
2016/09/05 Javascript
基于Marquee.js插件实现的跑马灯效果示例
2017/01/25 Javascript
vue2.0的contextmenu右键弹出菜单的实例代码
2017/07/24 Javascript
Vue父子模版传值及组件传值的三种方法
2017/11/27 Javascript
bootstrap响应式工具使用详解
2017/11/29 Javascript
javascript原生封装一个淡入淡出效果的函数测试实例代码
2018/03/19 Javascript
js中apply()和call()的区别与用法实例分析
2018/08/14 Javascript
vue 移动端适配方案详解
2018/11/15 Javascript
Element ui 下拉多选时新增一个选择所有的选项
2019/08/21 Javascript
解决Vue项目中tff报错的问题
2020/10/21 Javascript
Vue用mixin合并重复代码的实现
2020/11/27 Vue.js
[00:21]DOTA2亚洲邀请赛 Logo演绎
2015/02/07 DOTA
[01:06:26]全国守擂赛第二周 Team Coach vs DeMonsTer
2020/04/28 DOTA
Python常用模块介绍
2014/11/21 Python
自己编程中遇到的Python错误和解决方法汇总整理
2015/06/03 Python
Windows下安装python2和python3多版本教程
2017/03/30 Python
解决Mac下使用python的坑
2019/08/13 Python
Python安装tar.gz格式文件方法详解
2020/01/19 Python
python MultipartEncoder传输zip文件实例
2020/04/07 Python
Python json格式化打印实现过程解析
2020/07/21 Python
意大利宠物用品购物网站:Bauzaar
2018/09/15 全球购物
杭州联环马网络笔试题面试题
2013/08/04 面试题
一道输出判断型Java面试题
2014/10/01 面试题
母亲追悼会答谢词
2014/01/27 职场文书
药品业务员岗位职责
2014/04/17 职场文书
2014年党员自我评价材料
2014/09/22 职场文书
法人身份证明书
2014/10/08 职场文书
小学教师自我评价
2015/03/04 职场文书