這篇文章主要介紹了Vue中webpack常規(guī)打包優(yōu)化的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
目前成都創(chuàng)新互聯(lián)公司已為千余家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、網(wǎng)站改版維護、企業(yè)網(wǎng)站設(shè)計、石林網(wǎng)站維護等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。分析打包文件
要優(yōu)化,先分析。我們先要知道到底是哪里拖慢我們的打包速度呢?
打包后生成文件分析
可以利用 webpack-bundle-analyzer
插件來分析我們打包后生成的文件
安裝
npm i webpack-bundle-analyzer -D
使用
修改 webpack.prod.conf.js
文件
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin // 構(gòu)建完成后,瀏覽器會自動打開localhost:8080 webpackConfig.plugins.push( new BundleAnalyzerPlugin({ analyzerPort: 8080, generateStatsFile: false }) )
通過圖片可以看到打包后文件的具體信息
打包進度條顯示,可以查看到打包進度百分比
simple-progress-webpack-plugin
可以顯示打包百分比
安裝
npm i simple-progress-webpack-plugin -D
使用
修改 webpack.prod.conf.js
文件
const SimpleProgressWebpackPlugin = require( 'simple-progress-webpack-plugin' ) ... plugins: [ new SimpleProgressWebpackPlugin() ] ...
效果如下:
資源與依賴包的控制
通過上面進度可以看到,打包過程中,卡頓在壓縮的地方過長,當項目越來越臃腫的時候,我們要需要對項目靜態(tài)資源以及依賴包進行整理,
圖片過大的可以壓縮,這里推薦一個還不錯的壓縮 鏈接
項目中沒有使用的依賴可以刪除,可以按需引用的依賴,按需引用
項目里面使用 ElementUI 和 Echarts 都是全部引用掛在 Vue.prototype 上,現(xiàn)都改為按需引用。
減少文件搜索范圍
設(shè)置 resolve.alias
字段,避免打包時如果使用相對路徑訪問或著 import 文件時會層層去查找解析文件
resolve: { alias: { '@': resolve('src') } }
合理配置 extensions 擴展名
resolve.extensions
能夠自動解析確定的擴展,但是如果 extensions 擴展名過多,會導(dǎo)致解析過程過多,所以我們要合理配置擴展名,不要過多配置擴展名,項目引用多的文件,擴展名放在前面,我司項目中多的是 vue , js 文件,可以只引用這兩種。
resolve: { extensions: ['.vue', '.js'] }
loader 預(yù)處理文件增加 include 匹配特定條件
預(yù)處理各種文件時指定匹配目錄后, webpack 解析文件時就不會循環(huán)查找其他目錄,加快解析速度。
happypack 多線程執(zhí)行
webpack 執(zhí)行預(yù)處理文件時單線程的,我們可以使用 happypack 來多線程處理文件。
安裝
npm i happypack -D
使用
修改 webpack.base.js
文件
const happyThreadPool = HappyPack.ThreadPool({ size: os.cpus().length }); module: { rules: [ { test: /\.js$/, loader: 'happypack/loader?id=babel', // 原始loader替換成`happypack/loader` include: [resolve('src')] } ] }, plugins: [ new HappyPack({ // id標識 需要處理的loader id: 'babel', // loader配置和原始配置一樣 loaders: [ { loader: 'babel-loader', options: { presets: ['es2015'], cacheDirectory: true } } ], threadPool: happyThreadPool }) ]
babel-plugin-dynamic-import-node 異步加載
babel-plugin-dynamic-import-node
插件是使 import() 替換成 require 編譯
安裝
npm i babel-plugin-dynamic-import-node -D
使用
修改 .babelrc 文件
"env": { "development": { "plugins": ["dynamic-import-node"] }, "production": { "plugins": ["dynamic-import-node"] } }
注意:使用插件 build 后沒有 chunk files 文件。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“Vue中webpack常規(guī)打包優(yōu)化的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司,關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。