webpack 如何解析代碼模塊路徑的實(shí)現(xiàn)
前言
webpack是如何解析代碼模塊路徑
webpack 中有一個(gè)很關(guān)鍵的模塊 enhanced-resolve 就是處理依賴模塊路徑的解析的,這個(gè)模塊可以說(shuō)是 Node.js 那一套模塊路徑解析的增強(qiáng)版本,有很多可以自定義的解析配置。
模塊解析規(guī)則
解析相對(duì)路徑
- 查找相對(duì)當(dāng)前模塊的路徑下是否有對(duì)應(yīng)文件或文件夾
- 是文件則直接加載
- 是文件夾則繼續(xù)查找文件夾下的 package.json 文件
- 有 package.json 文件則按照文件中 main 字段的文件名來(lái)查找文件
- 無(wú) package.json 或者無(wú) main 字段則查找 index.js 文件.
解析模塊名
查找當(dāng)前文件目錄下,父級(jí)目錄及以上目錄下的 node_modules 文件夾,看是否有對(duì)應(yīng)名稱的模塊
解析絕對(duì)路徑(不建議使用)
直接查找對(duì)應(yīng)路徑的文件
在 webpack 配置中,和模塊路徑解析相關(guān)的配置都在 resolve 字段下:
module.exports = { resolve: { // ... } }
resolve.alias
假設(shè)我們有個(gè) utils 模塊極其常用,經(jīng)常編寫相對(duì)路徑很麻煩,希望可以直接 import 'utils' 來(lái)引用,那么我們可以配置某個(gè)模塊的別名,如:
alias: { utils: path.resolve(__dirname, 'src/utils') // 這里使用 path.resolve 和 __dirname 來(lái)獲取絕對(duì)路徑 }
上述的配置是模糊匹配,意味著只要模塊路徑中攜帶了 utils 就可以被替換掉,如:
import 'utils/query.js' // 等同于 import '[項(xiàng)目絕對(duì)路徑]/src/utils/query.js'
如果需要進(jìn)行精確匹配可以使用:
alias: { utils$: path.resolve(__dirname, 'src/utils') // 只會(huì)匹配 import 'utils' }
更多匹配相關(guān)的寫法可以參考官方文檔 Resolve Alias,這里不一一舉例說(shuō)明。
resolve.extensions
extensions: ['.wasm', '.mjs', '.js', '.json', '.jsx'], // 這里的順序代表匹配后綴的優(yōu)先級(jí),例如對(duì)于 index.js 和 index.jsx,會(huì)優(yōu)先選擇 index.js
看到數(shù)組中配置的字符串大概就可以猜到,這個(gè)配置的作用是和文件后綴名有關(guān)的。是的,這個(gè)配置可以定義在進(jìn)行模塊路徑解析時(shí),webpack 會(huì)嘗試幫你補(bǔ)全那些后綴名來(lái)進(jìn)行查找,例如有了上述的配置,當(dāng)你在 src/utils/ 目錄下有一個(gè) common.js 文件時(shí),就可以這樣來(lái)引用.
import * as common from './src/utils/common'
webpack 會(huì)嘗試給你依賴的路徑添加上 extensions 字段所配置的后綴,然后進(jìn)行依賴路徑查找,所以可以命中 src/utils/common.js 文件。
resolve.modules
前面的內(nèi)容有提到,對(duì)于直接聲明依賴名的模塊(如 react ),webpack 會(huì)類似 Node.js 一樣進(jìn)行路徑搜索,搜索 node_modules 目錄,這個(gè)目錄就是使用 resolve.modules 字段進(jìn)行配置的,默認(rèn)就是:
resolve: { modules: ['node_modules'], },
如果可以確定項(xiàng)目?jī)?nèi)所有的第三方依賴模塊都是在項(xiàng)目根目錄下的 node_modules 中的話,那么可以在 node_modules 之前配置一個(gè)確定的絕對(duì)路徑:
resolve: { modules: [ path.resolve(__dirname, 'node_modules'), // 指定當(dāng)前目錄下的 node_modules 優(yōu)先查找 'node_modules', // 如果有一些類庫(kù)是放在一些奇怪的地方的,你可以添加自定義的路徑或者目錄 ], }
這樣配置在某種程度上可以簡(jiǎn)化模塊的查找,提升構(gòu)建速度。
后言
resolve 還有一些其他的配置,還有其他的伙伴那就去官網(wǎng)看看,以上都是實(shí)際項(xiàng)目中使用到的。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 深入理解Webpack 中路徑的配置
- webpack打包后直接訪問(wèn)頁(yè)面圖片路徑錯(cuò)誤的解決方法
- webpack學(xué)習(xí)教程之publicPath路徑問(wèn)題詳解
- webpack+vue中使用別名路徑引用靜態(tài)圖片地址
- vue和webpack打包項(xiàng)目相對(duì)路徑修改的方法
- webpack踩坑之路圖片的路徑與打包
- Webpack中publicPath路徑問(wèn)題詳解
- webpack配置打包后圖片路徑出錯(cuò)的解決
- vue-cli webpack模板項(xiàng)目搭建及打包時(shí)路徑問(wèn)題的解決方法
- 解決vue-cli webpack打包后加載資源的路徑問(wèn)題
- 淺談webpack打包過(guò)程中因?yàn)閳D片的路徑導(dǎo)致的問(wèn)題
- 解決vue+webpack打包路徑的問(wèn)題
相關(guān)文章
javascript 函數(shù)參數(shù)限制說(shuō)明
我依稀記得哪本書上有說(shuō)過(guò),實(shí)參數(shù)限制是32個(gè)? 現(xiàn)在想想估計(jì)是我記錯(cuò)了..他也許說(shuō)的是32位.2010-11-11a標(biāo)簽click和href執(zhí)行順序探討
這篇文章主要介紹了a標(biāo)簽click和href執(zhí)行順序,需要的朋友可以參考下2014-06-06JS實(shí)現(xiàn)仿UC瀏覽器前進(jìn)后退效果的實(shí)例代碼
這篇文章主要介紹了JS實(shí)現(xiàn)仿UC瀏覽器前進(jìn)后退效果的實(shí)例代碼,實(shí)現(xiàn)此功能前需要先測(cè)試下瀏覽器,具體實(shí)例代碼,大家參考下本文2017-07-07JS遍歷JSON數(shù)組及獲取JSON數(shù)組長(zhǎng)度操作示例【測(cè)試可用】
這篇文章主要介紹了JS遍歷JSON數(shù)組及獲取JSON數(shù)組長(zhǎng)度操作,涉及javascript簡(jiǎn)單json數(shù)組遍歷與運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2018-12-12