node.js之path

  说到node.js,可能实际中用到node进行后台开发的公司不多,大部分人都没有开发后台的经验。但是也要了解node相关模块的用法,因为现在前端自动化脚本的构建,模块的打包越来越离不开node。特别是gulp或者webpack进行一些自动化操作的时候,node.js的重要性就体现出来了。说起来node毕竟是一个知识体系,所以想要几篇文章就描述清楚也是不可能的。本文就描述一下自动化构建中常用到的node的path模块。

  path是有关文件或文件夹的路径的模块,提供了获取文件路径,对路径进行转化,取得相对或者绝对路径等方法。具体如下:

  一、path.normalize(path) :标准化路径

var path = require('path');
/**
* 标准化路径
* */
var url1 = path.normalize('d/fec///sd///dsds');
var url2 = path.normalize('d/../..///ds');
console.dir('url1:'+url1);//'url1:d/fec/sd/dsds'
console.dir('url2:'+url2);//'url2:../ds'

  二、path.join([path1], [path2], [...]),合并路径

/**
* 合并路径
* */
var url3 = path.join('/a','b','a.text'),
url4 = path.join('//','a','b');
console.dir('url3:'+url3);//'url3:/a/b/a.text'
console.dir('url4:'+url4);//'url4:/a/b'

  三、path.resolve(a, b)获取a到b的绝对路径

/**
* 获取a到b的绝对路径
* 参数相当于执行路径转换的操作
* */
var url5 = path.resolve('E','b/a','../b/c','a.text'),
url6 = path.resolve('C','../D/a','../../A','s/a.text');
console.dir('url5:'+url5);//'url5:/Users/panqianjin/node/NodeCnpm/src/nodeApi/E/b/b/c/a.text'
console.dir('url6:'+url6);//'url6:/Users/panqianjin/node/NodeCnpm/src/nodeApi/A/s/a.text'

  四、path.isAbsolute(path):是否为绝对路径

/**
* 是否为绝对路径
* */
var url7 = path.isAbsolute('/E/a'),
url8 = path.isAbsolute('../c/a');
console.dir('url7:'+url7);//'url7:true'
console.dir('url8:'+url8);//'url8:false'

  五、path.relative(a, b):a到b的相对路径。a、b为绝对路径

/**
* 获取a到b的相对路径
* 参数为绝对路径,是resolve的逆操作
* */
var url9 = path.relative('E:/a','C:/d/b'),
url10 = path.relative('c/c/a','c/b');
console.dir('url9:'+url9);//'url9:../../C:/d/b'
console.dir('url10:'+url10);//'url10:../../b'

  六、path.dirname(path):返回路径中文件夹的路径

    path.basename(path):返回路径中的最后一部分,即dirname余下的部分

    path.extname(path):若存在返回文件的扩展名,否则为空

/**
* 返回路径中文件夹的路径
* */
var url11 = path.dirname('E:/a/C/d/b.text'),
url12 = path.dirname('c/c/a/');
console.dir('url11:'+url11);//'url11:E:/a/C/d'
console.dir('url12:'+url12);//'url12:c/c'
/**
* 返回路径中的最后一部分,为dirname余下的部分
* */
var url13 = path.basename('E:/a/C/d/b.text'),
url14 = path.basename('c/c/a/');
console.dir('url13:'+url13);//'url13:b.text'
console.dir('url14:'+url14);//'url14:a'
/**
* 若存在返回文件的扩展名,否则为空
* */
var url15 = path.extname('E:/a/C/d/b.text'),
url16 = path.extname('c/c/a/');
console.dir('url15:'+url15);//'url15:.text'
console.dir('url16:'+url16);//'url16:'

  七、path.sep:对应平台下的文件夹分隔符

    path.delimiter:对应平台下的路径分隔符

/**
* 对应平台下的文件夹分隔符
* mac下为/
* */
var url17 = path.sep,
url18 = 'c/c/a/'.split(path.sep);
console.dir('url17:'+url17);//'url17:/'
console.dir('url18:'+url18);//'url18:c,c,a'
/**
* 对应平台下的路径分隔符
* mac下为:
* */
var url17 = path.delimiter;
console.dir('url17:'+url17);//'url17::''

  path模块基本api和用法就是这样了,掌握了这些,在使用gulp或webpack的时候会更有效率的。  

上一篇:监控Activity的启动等状态--- 源码级


下一篇:JS之innerHTML,innerText,outerHTML,textContent的用法与区别