详解Node.js中path模块的resolve()和join()方法的区别
网络编程 2021-07-04 16:46www.168986.cn编程入门
这篇文章主要介绍了详解Node.js中path模块的resolve()和join()方法的区别,长沙网络推广觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
关于Node.js中path模块的resolve()和join()方法的比较,对照着看例子差不多以后在写模块的时候思路就能很清晰了
resolve
作用path.resolve() 该方法将一些的 路径/路径段 解析为绝对路径。
语法path.resolve([...paths])
说明
- ...paths <string> 一个路径或路径片段的序列
- 如果没有传入 path 片段,或者path 片段长度为零(空字符),则 path.resolve() 会返回当前工作目录的绝对路径(相当于使用path.resolve(__dirname))
例子我当前的工作路径为/workspace/demo
console.log(path.resolve()) // returns /workspace/demo console.log(path.resolve('')) // returns /workspace/demo console.log(path.resolve(__dirname)) // returns /workspace/demo console.log(path.resolve('/img/books', '/')) // returns '/' console.log(path.resolve('img/books', '/')) // returns '/' console.log(path.resolve('img/books', './')) // returns '/workspace/demo/img/books/' console.log(path.resolve('/img/books', './')) // returns '/img/books/' console.log(path.resolve('/img/books', '')) // returns '/img/books/' console.log(path.resolve('/img/books', '../')) // returns '/img/' console.log(path.resolve('src','/img/books', '../')) // returns '/img/' console.log(path.resolve('src','./img/books', '../')) // returns '/workspace/demo/src/img/' console.log(path.resolve('src','img/books', '../')) // returns '/workspace/demo/src/img/'
一下从后向前,若字符以 / 开头,不会拼接到前面的路径;若以 ../ 开头,拼接前面的路径,不含前面一节的一层路径;若以 ./ 开头 或者没有符号 则拼接前面路径;
join
作用path.join()方法使用平台特定的分隔符把全部给定的 path 片段连接到一起,并规范化生成的路径。
语法path.resolve([...paths])
说明
- ...paths <string> 一个路径或路径片段的序列
- 长度为零的 path 片段会被忽略。 如果连接后的路径字符串是一个长度为零的字符串,则返回 '.',表示当前工作目录
例子
path.join('/img', 'book', '/abc', 'inter', '..'); // returns /img/book//abc console.log(path.join('/img/books', '../')) // returns /img/ console.log(path.join('img/books', '../')) // returns img/ console.log(path.join('/img/books', './')) // returns /img/books/ console.log(path.join('img/books', './')) // returns img/books/ console.log(path.join('/img/books', '')) // returns /img/books/ console.log(path.join('img/books', '')) // returns /img/books/ console.log(path.join('/img/books', '/')) // returns /img/books/ console.log(path.join('img/books', '/')) // returns img/books/
一下 区别join()只是拼接各个path片段,并不像resolve()一样除了拼接各个字段还拼接了工作目录的路径,如果以/开头的字符串片段在join并不像resolve一样是只返回自身,还有就是.. 同 ../是一个意思都代表上一级目录
两者区别
1、join是把各个path片段连接在一起, resolve把‘/'当成根目录
path.join('/a', '/b') // Outputs '/a/b' path.resolve('/a', '/b') // Outputs '/b'
2、join直接拼接字段,resolve解析路径并返回
path.join("a", "b1", "..", "b2")
console打印会得到"a/b2"
path.resolve("a", "b1", "..", "b2")
console打印得到"/home/myself/node/a/b2"
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程