Node.js中path模塊的resolve()和join()方法的區別

關於Node.js中path模塊的resolve()和join()方法的比較,對照着總結看例子差很少之後在寫模塊的時候思路就能很清晰了前端

resolvenode

做用:path.resolve() 該方法將一些的 路徑/路徑段 解析爲絕對路徑。學習

語法:path.resolve([...paths])spa

說明:code

  • ...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'

前端全棧學習交流圈:866109386,面向1-3經驗年前端開發人員,幫助突破技術瓶頸,提高思惟能力,羣內有大量PDF可供自取,更有乾貨實戰項目視頻進羣免費領取。開發

總結一下:從後向前,若字符以 / 開頭,不會拼接到前面的路徑;若以 ../ 開頭,拼接前面的路徑,可是不含前面一節的最後一層路徑;若以 ./ 開頭 或者沒有符號 則拼接前面路徑;字符串

joinstring

做用:path.join()方法使用平臺特定的分隔符把所有給定的 path 片斷鏈接到一塊兒,並規範化生成的路徑。console

語法: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

前端全棧學習交流圈:866109386,面向1-3經驗年前端開發人員,幫助突破技術瓶頸,提高思惟能力,羣內有大量PDF可供自取,更有乾貨實戰項目視頻進羣免費領取。

總結一下 區別:join()只是拼接各個path片斷,並不像resolve()同樣除了拼接各個字段還拼接了工做目錄的路徑,其次若是以/開頭的字符串片斷在join並不像resolve同樣是只返回自身,還有就是.. 同 ../是一個意思都表明上一級目錄

二者區別:

一、join是把各個path片斷鏈接在一塊兒, resolve把‘/'當成根目錄

path.join('/a', '/b') // Outputs '/a/b'
path.resolve('/a', '/b') // Outputs '/b'

二、join直接拼接字段,resolve解析路徑並返回

path.join("a", "b1", "..", "b2")

console打印會獲得"a/b2"

path.resolve("a", "b1", "..", "b2")

console打印獲得"/home/myself/node/a/b2"

相關文章
相關標籤/搜索