Node.js中path模組的resolve()和join()方法的區別
關於Node.js中path模組的resolve()和join()方法的比較,對照著總結看例子差不多以後在寫模組的時候思路就能很清晰了
resolve
作用:path.resolve() 該方法將一些的 路徑/路徑段 解析為絕對路徑。
語法:path.resolve([…paths])
說明:
- …paths 一個路徑或路徑片段的序列
- 如果沒有傳入 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可供自取,更有乾貨實戰專案視訊進群免費領取。
總結一下:從後向前,若字元以 / 開頭,不會拼接到前面的路徑;若以 …/ 開頭,拼接前面的路徑,但是不含前面一節的最後一層路徑;若以 ./ 開頭 或者沒有符號 則拼接前面路徑;
join
作用:path.join()方法使用平臺特定的分隔符把全部給定的 path 片段連線到一起,並規範化生成的路徑。
語法:path.resolve([…paths])
說明:
- …paths 一個路徑或路徑片段的序列
- 長度為零的 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一樣是隻返回自身,還有就是… 同 …/是一個意思都代表上一級目錄
兩者區別:
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"