詳解webpack import()動態(tài)加載模塊踩坑
import
webpack根據(jù)ES2015 loader 規(guī)范實現(xiàn)了用于動態(tài)加載的import()方法。
這個功能可以實現(xiàn)按需加載我們的代碼,并且使用了promise式的回調(diào),獲取加載的包。
在代碼中所有被import()的模塊,都將打成一個單獨的包,放在chunk存儲的目錄下。在瀏覽器運行到這一行代碼時,就會自動請求這個資源,實現(xiàn)異步加載。
這里是一個簡單的demo。
import('lodash').then(_ => { // Do something with lodash (a.k.a '_')... })
可以看到,import()的語法十分簡單。該函數(shù)只接受一個參數(shù),就是引用包的地址,這個地址與es6的import以及CommonJS的require語法用到的地址完全一致??梢詫崿F(xiàn)無縫切換【寫個正則替換美滋滋】。
并且使用了Promise的封裝,開發(fā)起來感覺十分自在。【包裝一個async函數(shù)就更爽了】
然而,以上只是表象。
只是表象。
我在開發(fā)的時候就遇到了問題。場景是這樣的:一個對象,存儲的是各級的路由信息,及其對應(yīng)的頁面組件。為減少主包大小,我們希望動態(tài)加載這些頁面。
同時使用了react-loadable來簡化組件的懶加載封裝。代碼如下所示。
function lazyLoad(path) { return Loadable({ loader: () => import(path), loading: Spin, }); }
然后我就開始開心的在代碼中寫上lazyLoad('./pages/xxx')。果不其然,掛了。瀏覽器表示,沒有魚丸沒有粗面,也不知道這個傻逼模塊在哪里。
于是我查看了官方文檔,發(fā)現(xiàn)有一個黃條提示。
emmm,看來問題出在這里了。
這個現(xiàn)象其實是與webpack import()的實現(xiàn)高度相關(guān)的。由于webpack需要將所有import()的模塊都進行單獨打包,所以在工程打包階段,webpack會進行依賴收集。
此時,webpack會找到所有import()的調(diào)用,將傳入的參數(shù)處理成一個正則,如:
import('./app'+path+'/util') => /^\.\/app.*\/util$/
也就是說,import參數(shù)中的所有變量,都會被替換為【.*】,而webpack就根據(jù)這個正則,查找所有符合條件的包,將其作為package進行打包。
因此,如果我們直接傳入一個變量,webpack就會把 (整個電腦的包都打包進來[不鬧]) 認(rèn)為你在逗他,并且拋出一個WARNING: Critical dependency: the request of a dependency is an expression。
所以import的正確姿勢,應(yīng)該是盡可能靜態(tài)化表達(dá)包所處的路徑,最小化變量控制的區(qū)域
。
如我們要引用一堆頁面組件,可以使用import('./pages/'+ComponentName),這樣就可以實現(xiàn)引用的封裝,同時也避免打包多余的內(nèi)容。
另外一個影響功能封裝的點,是import()中的相對路徑
,是import語句所在文件的相對路徑,所以進一步封裝import時會出現(xiàn)一些麻煩。
因為import語句中的路徑會在編譯后被處理成webpack命令執(zhí)行目錄的相對路徑.
友情鏈接:https://webpack.js.org/api/module-methods/#import
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JS實現(xiàn)京東首頁之頁面頂部、Logo和搜索框功能
這篇文章主要實現(xiàn)京東的頁面頂部,logo和搜索框功能,本文有效果展示,頁面布局詳細(xì)分析,具體實現(xiàn)代碼,介紹的非常詳細(xì),具有參考借鑒價值,需要的的朋友參考下吧2017-01-01JavaScript實現(xiàn)網(wǎng)頁頭部進度條刷新
這篇文章主要介紹了JavaScript實現(xiàn)網(wǎng)頁頭部進度條刷新實例代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-04-04JavaScript實現(xiàn)廣告的關(guān)閉與顯示效果實例
這篇文章主要介紹了JavaScript實現(xiàn)廣告的關(guān)閉與顯示效果,涉及javascript廣告窗口的關(guān)閉與顯示效果實現(xiàn)技巧,需要的朋友可以參考下2015-07-07JavaScript手寫源碼之omit函數(shù)的實現(xiàn)
最近突然有個新的想法,想去看看前端的小庫來提升自己的編碼能力。但是又不知道怎么去證明自己是否真的看懂了,那就實現(xiàn)一個omit函數(shù)吧2023-02-02js實現(xiàn)GridView單選效果自動設(shè)置交替行、選中行、鼠標(biāo)移動行背景色
使用js實現(xiàn)GridView單選效果自動設(shè)置交替行、選中行、鼠標(biāo)移動行背景色2010-05-05Javascript中從學(xué)習(xí)bind到實現(xiàn)bind的過程
這篇文章主要介紹了Javascript中從學(xué)習(xí)bind到實現(xiàn)bind的過程,有興趣的朋友跟著學(xué)習(xí)下吧。2018-01-01