详解Node.js中path模块的resolve()和join()方法的区别


Posted in Javascript onOctober 29, 2018

关于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', '/net'))  // returns '/net'
console.log(path.resolve('img/books', '/net'))  // returns '/net'
console.log(path.resolve('img/books', './net'))  // returns '/workspace/demo/img/books/net'
console.log(path.resolve('/img/books', './net'))  // returns '/img/books/net'
console.log(path.resolve('/img/books', 'net'))   // returns '/img/books/net'
console.log(path.resolve('/img/books', '../net'))     // returns '/img/net'
console.log(path.resolve('src','/img/books', '../net'))  // returns '/img/net'
console.log(path.resolve('src','./img/books', '../net'))  // returns '/workspace/demo/src/img/net'
console.log(path.resolve('src','img/books', '../net'))   // returns '/workspace/demo/src/img/net'

总结一下:从后向前,若字符以 / 开头,不会拼接到前面的路径;若以 ../ 开头,拼接前面的路径,但是不含前面一节的最后一层路径;若以 ./ 开头 或者没有符号 则拼接前面路径;

join

作用:path.join()方法使用平台特定的分隔符把全部给定的 path 片段连接到一起,并规范化生成的路径。

语法:path.resolve([...paths])

说明:

  • ...paths <string> 一个路径或路径片段的序列
  • 长度为零的 path 片段会被忽略。 如果连接后的路径字符串是一个长度为零的字符串,则返回 '.',表示当前工作目录

例子:

path.join('/img', 'book', 'net/abc', 'inter', '..'); // returns /img/book/net/abc
console.log(path.join('/img/books', '../net'))  // returns /img/net
console.log(path.join('img/books', '../net'))   // returns img/net
console.log(path.join('/img/books', './net'))   // returns /img/books/net
console.log(path.join('img/books', './net'))   // returns img/books/net
console.log(path.join('/img/books', 'net'))    // returns /img/books/net
console.log(path.join('img/books', 'net'))    // returns /img/books/net
console.log(path.join('/img/books', '/net'))   // returns /img/books/net
console.log(path.join('img/books', '/net'))    // returns img/books/net

总结一下 区别: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"

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
ext checkboxgroup 回填数据解决
Aug 21 Javascript
Javascript 判断客户端浏览器类型代码
Mar 01 Javascript
express的中间件bodyParser详解
Dec 04 Javascript
Angularjs全局变量被作用域监听的正确姿势
Feb 06 Javascript
Centos6.8下Node.js安装教程
May 12 Javascript
jQuery实现checkbox的简单操作
Nov 18 jQuery
JavaScript内存泄漏的处理方式
Nov 20 Javascript
详解VUE 数组更新
Dec 16 Javascript
使用百度地图实现地图网格的示例
Feb 06 Javascript
基于webpack4+vue-cli3项目实现换肤功能
Jul 17 Javascript
jQuery表单选择器用法详解
Aug 22 jQuery
vue v-on:click传递动态参数的步骤
Sep 11 Javascript
详解vue-router数据加载与缓存使用总结
Oct 29 #Javascript
vue mounted 调用两次的完美解决办法
Oct 29 #Javascript
Electron中实现大文件上传和断点续传功能
Oct 28 #Javascript
JS 正则表达式验证密码、邮箱格式的实例代码
Oct 28 #Javascript
Js 利用正则表达式和replace函数获取string中所有被匹配到的文本(推荐)
Oct 28 #Javascript
深入浅析javascript函数中with
Oct 28 #Javascript
微信小程序动画(Animation)的实现及执行步骤
Oct 28 #Javascript
You might like
最贵的咖啡是怎么产生的,它的风味怎么样?
2021/03/04 新手入门
php与paypal整合方法
2010/11/28 PHP
基于php验证码函数的使用示例
2013/05/03 PHP
php递归方法实现无限分类实例代码
2014/02/28 PHP
THINKPHP项目开发中的日志记录实例分析
2014/12/01 PHP
微信access_token的获取开发示例
2015/04/16 PHP
CI框架常用方法小结
2016/05/17 PHP
iOS10推送通知开发教程
2016/09/19 PHP
单击复制文字兼容各浏览器的完美解决方案
2013/07/04 Javascript
JS中typeof与instanceof之间的区别总结
2013/11/14 Javascript
Jquery解析json数据详解
2013/12/26 Javascript
JS获取单击按钮单元格所在行的信息
2014/06/17 Javascript
使用JavaScript的AngularJS库编写hello world的方法
2015/06/23 Javascript
基于JavaScript实现动态创建表格和增加表格行数
2015/12/20 Javascript
jquery实现列表上下移动功能
2016/02/25 Javascript
JavaScript的Vue.js库入门学习教程
2016/05/23 Javascript
微信小程序教程系列之新建页面(4)
2017/04/17 Javascript
node.js-v6新版安装具体步骤(分享)
2017/09/06 Javascript
JS实现前端缓存的方法
2017/09/21 Javascript
js实现把时间戳转换为yyyy-MM-dd hh:mm 格式(es6语法)
2017/12/28 Javascript
vue中render函数的使用详解
2018/10/12 Javascript
vue图片上传本地预览组件使用详解
2019/02/20 Javascript
JavaScript函数IIFE使用详解
2019/10/21 Javascript
jQuery实现获取多选框的值示例
2020/02/07 jQuery
Element Alert警告的具体使用方法
2020/07/27 Javascript
Vue实现input宽度随文字长度自适应操作
2020/07/29 Javascript
原生js实现弹窗消息动画
2020/11/20 Javascript
[40:57]TI4 循环赛第二日 iG vs EG
2014/07/11 DOTA
python多进程共享变量
2016/04/06 Python
python的pip有什么用
2020/06/17 Python
基于CSS3制作立体效果导航菜单
2016/01/12 HTML / CSS
英国HYPE双肩包官网:英国本土时尚潮牌
2018/09/26 全球购物
Simons官方网站:加拿大时尚零售商
2020/02/20 全球购物
pytorch实现ResNet结构的实例代码
2021/05/17 Python
ROS系统将python包编译为可执行文件的简单步骤
2021/07/25 Python
Python实现文字pdf转换图片pdf效果
2022/04/03 Python