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', '/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一樣是隻返回自身,還有就是..../是一個意思都代表上一級目錄

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章