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

关于Node.js中path模块的resolve()和join()方法的比较,对照着总结看例子差很少之后在写模块的时候思路就能很清晰了

resolve

做用:path.resolve() 该方法将一些的 路径/路径段 解析为绝对路径。spa

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

说明:字符串

  • ...paths <string> 一个路径或路径片断的序列
  • 若是没有传入 path 片断,或者path 片断长度为零(空字符),则 path.resolve() 会返回当前工做目录的绝对路径(至关于使用path.resolve(__dirname))

例子:我当前的工做路径为/workspace/demostring

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'

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

join

做用:path.join()方法使用平台特定的分隔符把所有给定的 path 片断链接到一块儿,并规范化生成的路径。语法

语法:path.join([...paths])方法

说明:im

  • ...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同样是只返回自身,还有就是..../是一个意思都表明上一级目录demo

相关文章
相关标签/搜索