摘要:前言之前在做配置时候多次用到路径相关内容,最近在写项目的时候,有一个文件需要上传到阿里云的功能,同时本地服务器也需要保留一个文件备份。如果返回的路径字符串长度为零,那么他会返回一个,代表当前的文件夹。
前言
之前在做webpack配置时候多次用到路径相关内容,最近在写项目的时候,有一个文件需要上传到阿里云oss的功能,同时本地服务器也需要保留一个文件备份。多次用到了文件路径相关内容以及Node核心API的path模块,所以系统的学习了一下,整理了这篇文章。
node中的路径分类node中的路径大致分5类,dirname,filename,process.cwd(),./,../,其中dirname,filename,process.cwd()绝对路径
通过代码对每个分类进行说明:
文件目录结构如下:
</>复制代码
代码pra/
- node核心API/
- fs.js
- path.js
path.js中的代码
</>复制代码
const path = require("path");
console.log(__dirname);
console.log(__filename);
console.log(process.cwd());
console.log(path.resolve("./"));
在代码pra目录下运行命令 node node核心API/path.js,我们可以看到结果如下:
</>复制代码
/koala/Desktop/程序员成长指北/代码pra/node核心API
/koala/Desktop/程序员成长指北/代码pra/node核心API/path.js
/koala/Desktop/程序员成长指北/代码pra
/koala/Desktop/程序员成长指北/代码pra
然后我们有可以在node核心API目录下运行这个文件,node path.js,运行结果如下:
</>复制代码
/koala/Desktop/程序员成长指北/代码pra/node核心API
/koala/Desktop/程序员成长指北/代码pra/node核心API/path.js
/koala/Desktop/程序员成长指北/代码pra/node核心API
/koala/Desktop/程序员成长指北/代码pra/node核心API
对比输出结果,暂时得到的结论是
__dirname: 总是返回被执行的 js 所在文件夹的绝对路径
__filename: 总是返回被执行的 js 的绝对路径
process.cwd(): 总是返回运行 node 命令时所在的文件夹的绝对路径
./: 跟 process.cwd() 一样,返回 node 命令时所在的文件夹的绝对路径
为什么说上面是暂时得到的结论,因为是有错误的,再看一段代码:
我们在path.js中加上这句代码
</>复制代码
exports.A = 1;
之前直接通过readFile读取文件路径报错,
</>复制代码
fs.readFile("./path.js",function(err,data){
});
现在在刚才报错的fs.js里面加这两句代码看看:
</>复制代码
const test = require("./path.js");
console.log(test)
在代码pra/目录下运行node node核心API/fs.js,最后查看结果,说明是可以访问到的:
</>复制代码
{ A: 1 }
那么关于 ./ 正确的结论是:
在 require() 中使用是跟 __dirname 的效果相同,不会因为启动脚本的目录不一样而改变,在其他情况下跟 process.cwd() 效果相同,是相对于启动脚本所在目录的路径。
路径知识总结:__dirname: 获得当前执行文件所在目录的完整目录名
__filename: 获得当前执行文件的带有完整绝对路径的文件名
process.cwd():获得当前执行node命令时候的文件夹目录名
./: 不使用require时候,./与process.cwd()一样,使用require时候,与__dirname一样
只有在 require() 时才使用相对路径(./, ../) 的写法,其他地方一律使用绝对路径,如下:
</>复制代码
// 当前目录下
path.dirname(__filename) + "/path.js";
// 相邻目录下
path.resolve(__dirname, "../regx/regx.js");
path
前面讲解了路径的相关比较,接下来多带带聊聊path这个模块,这个模块在很多地方比较常用,所以,对于我们来说,掌握他,对我们以后的发展更有利,不用每次看webpack的配置文件还要去查询一下这个api是干什么用的,很影响我们的效率
</>复制代码
这是api官网地址:https://nodejs.org/api/path.html
个人认为官网中的api没有必要都掌握,下面会对一些常用的api进行讲解,我经常用到的,或者作为一个前端开发工程师在webpack等工程配置的时候经常用到的。
path.normalize举例说明
</>复制代码
const path = require("path");
console.log(path.normalize("/koala/Desktop//程序员成长指北//代码pra/.."));
规范后的结果
</>复制代码
/koala/Desktop/程序员成长指北/代码pra
作用总结
规范化路径,把不规范的路径规范化。
path.join举例说明
</>复制代码
const path = require("path");
console.log(path.join("src", "task.js"));
const path = require("path");
console.log(path.join(""));
转化后的结果
</>复制代码
src/task.js
.
作用总结
</>复制代码
path.join([...paths])
传入的参数是字符串的路径片段,可以是一个,也可以是多个
返回的是一个拼接好的路径,但是根据平台的不同,他会对路径进行不同的规范化,举个例子,Unix系统是/,Windows系统是,那么你在两个系统下看到的返回结果就不一样。
如果返回的路径字符串长度为零,那么他会返回一个.,代表当前的文件夹。
如果传入的参数中有不是字符串的,那就直接会报错
path.parse举例说明
</>复制代码
const path = require("path");
console.log(path.parse("/koala/Desktop/程序员成长指北/代码pra/node核心API"));
运行结果
</>复制代码
{ root: "/",
dir: "/koala/Desktop/程序员成长指北/代码pra",
base: "node核心API",
ext: "",
name: "node核心API"
}
作用总结
他返回的是一个对象,那么我们来把这么几个名词熟悉一下:
root:代表根目录
dir:代表文件所在的文件夹
base:代表整一个文件
name:代表文件名
ext: 代表文件的后缀名
path.basename举例说明
</>复制代码
const path = require("path");
console.log(path.basename("/koala/Desktop/程序员成长指北/代码pra/node核心API"));
console.log(path.basename("/koala/Desktop/程序员成长指北/代码pra/node核心API/path.js", ".js"));
运行结果
看了上面代码的例子,我想应该知道了basename结果,嘿嘿。
</>复制代码
node核心API
path
作用总结
basename接收两个参数,第一个是path,第二个是ext(可选参数),当输入第二个参数的时候,打印结果不出现后缀名
path.dirname举例说明
</>复制代码
const path = require("path");
console.log(path.dirname("/koala/Desktop/程序员成长指北/代码pra/node核心API"));
运行结果
</>复制代码
/koala/Desktop/程序员成长指北/代码pra
作用总结
返回文件的目录完整地址
path.extname举例说明
</>复制代码
const path = require("path");
path.extname("index.html");
path.extname("index.coffee.md");
path.extname("index.");
path.extname("index");
path.extname(".index");
运行结果
</>复制代码
.html
.md
.
""
""
作用总结
返回的是后缀名,但是最后两种情况返回"",大家注意一下。
path.resolve举例说明
</>复制代码
const path = require("path");
console.log(path.resolve("/foo/bar", "/bar/faa", "..", "a/../c"));
输出结果
</>复制代码
/bar/c
作用总结
</>复制代码
path.resolve([...paths])
path.resolve就相当于是shell下面的cd操作,从左到右运行一遍cd path命令,最终获取的绝对路径/文件名,这个接口所返回的结果了。但是resolve操作和cd操作还是有区别的,resolve的路径可以没有,而且最后进入的可以是文件。具体cd步骤如下
</>复制代码
cd /foo/bar/ //这是第一步, 现在的位置是/foo/bar/
cd /bar/faa //这是第二步,这里和第一步有区别,他是从/进入的,也就时候根目录,现在的位置是/bar/faa
cd .. //第三步,从faa退出来,现在的位置是 /bar
cd a/../c //第四步,进入a,然后在推出,在进入c,最后位置是/bar/c
path.relative
举例说明
</>复制代码
const path = require("path");
console.log(path.relative("/data/orandea/test/aaa", "/data/orandea/impl/bbb"));
console.log(path.relative("/data/demo", "/data/demo"));
console.log(path.relative("/data/demo", ""));
运行结果
</>复制代码
../../impl/bbb
""
../../koala/Desktop/程序员成长指北/代码pra/node核心API
作用总结
path.relative(from, to)
描述:从from路径,到to路径的相对路径。
边界:
如果from、to指向同个路径,那么,返回空字符串。
如果from、to中任一者为空,那么,返回当前工作路径。
总结本篇文章关于路径的知识就说到这里,基础很重要的,既能节约开发时间,又能减少报错。
今天就分享这么多,如果对分享的内容感兴趣,可以关注公众号「程序员成长指北」,或者加入技术交流群,大家一起讨论。
进阶技术路线
加入我们一起学习吧!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/110060.html
摘要:在他的重学前端课程中提到到现在为止,前端工程师已经成为研发体系中的重要岗位之一。大部分前端工程师的知识,其实都是来自于实践和工作中零散的学习。一基础前端工程师吃饭的家伙,深度广度一样都不能差。 开篇 前端开发是一个非常特殊的行业,它的历史实际上不是很长,但是知识之繁杂,技术迭代速度之快是其他技术所不能比拟的。 winter在他的《重学前端》课程中提到: 到现在为止,前端工程师已经成为研...
摘要:在他的重学前端课程中提到到现在为止,前端工程师已经成为研发体系中的重要岗位之一。大部分前端工程师的知识,其实都是来自于实践和工作中零散的学习。一基础前端工程师吃饭的家伙,深度广度一样都不能差。开篇 前端开发是一个非常特殊的行业,它的历史实际上不是很长,但是知识之繁杂,技术迭代速度之快是其他技术所不能比拟的。 winter在他的《重学前端》课程中提到: 到现在为止,前端工程师已经成为研发体系...
摘要:由于文章内容较长,所以我把它分成两篇小文章,在第一篇优秀架构师必须掌握的架构思维中,我会先介绍抽象分层分治和演化这四种应对复杂性的基本思维。另外,上面的算法是两路归并,也可以采用多路归并,甚至是采用堆排序进行优化,但是总体分治思路没有变化。 showImg(https://segmentfault.com/img/bVbeYpP?w=642&h=400); 介绍 架构的本质是管理复杂性...
摘要:由于文章内容较长,所以我把它分成两篇小文章,在第一篇优秀架构师必须掌握的架构思维中,我会先介绍抽象分层分治和演化这四种应对复杂性的基本思维。另外,上面的算法是两路归并,也可以采用多路归并,甚至是采用堆排序进行优化,但是总体分治思路没有变化。 showImg(https://segmentfault.com/img/bVbeYpP?w=642&h=400); 介绍 架构的本质是管理复杂性...
阅读 1268·2021-11-15 18:00
阅读 1875·2021-10-08 10:15
阅读 908·2021-09-04 16:48
阅读 2544·2021-09-04 16:48
阅读 1378·2019-08-29 18:40
阅读 1045·2019-08-29 13:08
阅读 3135·2019-08-26 14:06
阅读 1206·2019-08-26 13:35
极致性价比!云服务器续费无忧!
Tesla A100/A800、Tesla V100S等多种GPU云主机特惠2折起,不限台数,续费同价。
NVIDIA RTX 40系,高性价比推理显卡,满足AI应用场景需要。
乌兰察布+上海青浦,满足东推西训AI场景需要