關於Node.js中path模塊的resolve()和join()方法的比較,對照着總結看例子差很少之後在寫模塊的時候思路就能很清晰了
做用:path.resolve() 該方法將一些的 路徑/路徑段 解析爲絕對路徑。spa
語法:path.resolve([...paths])code
說明:字符串
例子:我當前的工做路徑爲/workspace/demo
string
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
做用:path.join()方法使用平臺特定的分隔符把所有給定的 path 片斷鏈接到一塊兒,並規範化生成的路徑。語法
語法:path.join([...paths])方法
說明:im
例子:總結
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