小編給大家分享一下webpack解析代碼模塊路徑的實(shí)現(xiàn)方法,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
創(chuàng)新互聯(lián)主要從事網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)鄆城,10多年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18982081108前言
webpack是如何解析代碼模塊路徑
webpack 中有一個(gè)很關(guān)鍵的模塊 enhanced-resolve 就是處理依賴模塊路徑的解析的,這個(gè)模塊可以說是 Node.js 那一套模塊路徑解析的增強(qiáng)版本,有很多可以自定義的解析配置。
模塊解析規(guī)則
解析相對路徑
查找相對當(dāng)前模塊的路徑下是否有對應(yīng)文件或文件夾
是文件則直接加載
是文件夾則繼續(xù)查找文件夾下的 package.json 文件
有 package.json 文件則按照文件中 main 字段的文件名來查找文件
無 package.json 或者無 main 字段則查找 index.js 文件.
解析模塊名
查找當(dāng)前文件目錄下,父級目錄及以上目錄下的 node_modules 文件夾,看是否有對應(yīng)名稱的模塊
解析絕對路徑(不建議使用)
直接查找對應(yīng)路徑的文件
在 webpack 配置中,和模塊路徑解析相關(guān)的配置都在 resolve 字段下:
module.exports = { resolve: { // ... } }
resolve.alias
假設(shè)我們有個(gè) utils 模塊極其常用,經(jīng)常編寫相對路徑很麻煩,希望可以直接 import 'utils' 來引用,那么我們可以配置某個(gè)模塊的別名,如:
alias: { utils: path.resolve(__dirname, 'src/utils') // 這里使用 path.resolve 和 __dirname 來獲取絕對路徑 }
上述的配置是模糊匹配,意味著只要模塊路徑中攜帶了 utils 就可以被替換掉,如:
import 'utils/query.js' // 等同于 import '[項(xiàng)目絕對路徑]/src/utils/query.js'
如果需要進(jìn)行精確匹配可以使用:
alias: { utils$: path.resolve(__dirname, 'src/utils') // 只會匹配 import 'utils' }
更多匹配相關(guān)的寫法可以參考官方文檔 Resolve Alias,這里不一一舉例說明。
resolve.extensions
extensions: ['.wasm', '.mjs', '.js', '.json', '.jsx'], // 這里的順序代表匹配后綴的優(yōu)先級,例如對于 index.js 和 index.jsx,會優(yōu)先選擇 index.js
看到數(shù)組中配置的字符串大概就可以猜到,這個(gè)配置的作用是和文件后綴名有關(guān)的。是的,這個(gè)配置可以定義在進(jìn)行模塊路徑解析時(shí),webpack 會嘗試幫你補(bǔ)全那些后綴名來進(jìn)行查找,例如有了上述的配置,當(dāng)你在 src/utils/ 目錄下有一個(gè) common.js 文件時(shí),就可以這樣來引用.
import * as common from './src/utils/common'
webpack 會嘗試給你依賴的路徑添加上 extensions 字段所配置的后綴,然后進(jìn)行依賴路徑查找,所以可以命中 src/utils/common.js 文件。
resolve.modules
前面的內(nèi)容有提到,對于直接聲明依賴名的模塊(如 react ),webpack 會類似 Node.js 一樣進(jìn)行路徑搜索,搜索 node_modules 目錄,這個(gè)目錄就是使用 resolve.modules 字段進(jìn)行配置的,默認(rèn)就是:
resolve: { modules: ['node_modules'], },
如果可以確定項(xiàng)目內(nèi)所有的第三方依賴模塊都是在項(xiàng)目根目錄下的 node_modules 中的話,那么可以在 node_modules 之前配置一個(gè)確定的絕對路徑:
resolve: { modules: [ path.resolve(__dirname, 'node_modules'), // 指定當(dāng)前目錄下的 node_modules 優(yōu)先查找 'node_modules', // 如果有一些類庫是放在一些奇怪的地方的,你可以添加自定義的路徑或者目錄 ], }
這樣配置在某種程度上可以簡化模塊的查找,提升構(gòu)建速度。
后言
resolve 還有一些其他的配置,還有其他的伙伴那就去官網(wǎng)看看,以上都是實(shí)際項(xiàng)目中使用到的。
看完了這篇文章,相信你對“webpack解析代碼模塊路徑的實(shí)現(xiàn)方法”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,感謝各位的閱讀!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
本文名稱:webpack解析代碼模塊路徑的實(shí)現(xiàn)方法-創(chuàng)新互聯(lián)
路徑分享:http://www.rwnh.cn/article26/pdocg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、定制開發(fā)、企業(yè)建站、營銷型網(wǎng)站建設(shè)、自適應(yīng)網(wǎng)站、微信公眾號
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容