本篇文章帶大家了解一下nodejs中的path.join和path.resolve,介紹一下path.join和path.resolve的區(qū)別,希望對大家有所幫助!
相信小伙伴們都對這兩個方法path.join
、path.resolve
不陌生,在我們寫node或者配置webpack的時候都用過該方法。比如下面這段:
output: { path: Path.join(__dirname, "dist"), filename: "[name]_[chunkhash:8].js" }
但是你知道這兩個的區(qū)別嗎。今天筆者就來講一下二者區(qū)別及用法。
先說一下,path
為我們node
中的一個內(nèi)置模塊,這兩個方法都是path
模塊下提供的。
Path.resolve
不廢話,先上圖。我們可以看到resolve
方法接收無限的參數(shù)且都是string類型的,該方法返回值也是string
類型的(是一個路徑)。
栗子:
// 這里我們就當__dirname是 /root path.resolve(__dirname, "./dist") // 輸出:/root/dist path.resolve(__dirname, "dist", "dir") // 輸出:/root/dist/dir path.resolve(__dirname, "/dist") // 輸出:/dist path.resolve(__dirname, "/dist", "../") // 輸出:你的磁盤根目錄 path.resolve(__dirname, "/dist", "..") // 輸出:你的磁盤根目錄 path.resolve(__dirname, "/dist", "..", "/test") // 輸出:/test path.resolve(__dirname, "dist", "dir", "/test") // 輸出:/test path.resolve(__dirname, "dist", null, "/test") // 輸出:報錯,參數(shù)一定要字符串類型的!
通過上面栗子我們可以看到,參數(shù)可以任意,返回值是一個路徑(string類型)。然而上面的結(jié)果是當我們的參數(shù)里面遇見/
就是根路徑的時候,這時返回值路徑會發(fā)生極大改變,變化為:以最后一次出現(xiàn)/
根路徑的值為當前路徑的開始。
Path.join
join
方法跟resolve
方法一樣,接收無限的參數(shù),返回值也是string類型。join
顧名思義就是拼接意思。我們來看一下join
的用法吧
栗子:
// 這里我們就當__dirname是 /root path.join(__dirname, "dist") // 輸出:/root/dist path.join(__dirname, "dist", "/dir") // 輸出:/root/dist/dir path.join(__dirname, "dist", "/dir", "..") // 輸出:/root/dist path.join(__dirname, "dist", "/dir", "../test") // 輸出:/root/dist/test path.join(__dirname, "dist", "/dir", "/..test") // 輸出:/root/dist/dir/..test path.join(__dirname, "/dist", "..") // 輸出:/root
通過上面栗子我們可以看到join
方法只是拼接路徑,也不會像resolve
那樣遇見/
根就直接把整個路徑替換跳,而只有在標準的..
、../
相對路徑的時候跳出目錄。
二者區(qū)別
通過上面的兩個栗子,我相信你可以總結(jié)出二者的區(qū)別在哪里了。說白了就是resolve
方法是對根路徑的而直接變化的,而join
方法只會將所有參數(shù)拼接,最后形成一個完整的路徑(當然遇見..
or../
會跳出當前目錄)。
這個在實際開發(fā)中配置還是用到的地方很多的,有時候我們寫字符串../src/index.html
不生效時,就可以試試resove
or join
哦。
完!就分享到這吧,希望可以對大家漲一點小知識,如有幫助請幫該文章點個贊和在看吧,讓