Vue項(xiàng)目總結(jié)之webpack常規(guī)打包優(yōu)化方案
由于新建項(xiàng)目發(fā)版打包時(shí)間大概需要 30分鐘 ,發(fā)版時(shí) 嚴(yán)重 拖慢 下班 時(shí)間,所以特意查看了相關(guān)文檔來優(yōu)化打包速度,爭(zhēng)取早點(diǎn)下班,^_^。
分析打包文件
要優(yōu)化,先分析。我們先要知道到底是哪里拖慢我們的打包速度呢?
打包后生成文件分析
可以利用 webpack-bundle-analyzer
插件來分析我們打包后生成的文件
安裝
npm i webpack-bundle-analyzer -D
使用
修改 webpack.prod.conf.js
文件
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin // 構(gòu)建完成后,瀏覽器會(huì)自動(dòng)打開localhost:8080 webpackConfig.plugins.push( new BundleAnalyzerPlugin({ analyzerPort: 8080, generateStatsFile: false }) )
通過圖片可以看到打包后文件的具體信息
打包進(jìn)度條顯示,可以查看到打包進(jìn)度百分比
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() ] ...
效果如下:
資源與依賴包的控制
通過上面進(jìn)度可以看到,打包過程中,卡頓在壓縮的地方過長(zhǎng),當(dāng)項(xiàng)目越來越臃腫的時(shí)候,我們要需要對(duì)項(xiàng)目靜態(tài)資源以及依賴包進(jìn)行整理,
圖片過大的可以壓縮,這里推薦一個(gè)還不錯(cuò)的壓縮 鏈接
- 項(xiàng)目中沒有使用的依賴可以刪除,可以按需引用的依賴,按需引用
- 項(xiàng)目里面使用 ElementUI 和 Echarts 都是全部引用掛在 Vue.prototype 上,現(xiàn)都改為按需引用。
減少文件搜索范圍
設(shè)置 resolve.alias
字段,避免打包時(shí)如果使用相對(duì)路徑訪問或著 import 文件時(shí)會(huì)層層去查找解析文件
resolve: { alias: { '@': resolve('src') } }
合理配置 extensions 擴(kuò)展名
resolve.extensions
能夠自動(dòng)解析確定的擴(kuò)展,但是如果 extensions 擴(kuò)展名過多,會(huì)導(dǎo)致解析過程過多,所以我們要合理配置擴(kuò)展名,不要過多配置擴(kuò)展名,項(xiàng)目引用多的文件,擴(kuò)展名放在前面,我司項(xiàng)目中多的是 vue , js 文件,可以只引用這兩種。
resolve: { extensions: ['.vue', '.js'] }
loader 預(yù)處理文件增加 include 匹配特定條件
預(yù)處理各種文件時(shí)指定匹配目錄后, webpack 解析文件時(shí)就不會(huì)循環(huán)查找其他目錄,加快解析速度。
happypack 多線程執(zhí)行
webpack 執(zhí)行預(yù)處理文件時(shí)單線程的,我們可以使用 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標(biāo)識(shí) 需要處理的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 文件。
總結(jié)
項(xiàng)目經(jīng)過以上優(yōu)化,打包從 30 分鐘,到 2 分鐘,整體還有優(yōu)化空間,可以使用其他 cdn , dll 等優(yōu)化方式。
以上所述是小編給大家介紹的Vue項(xiàng)目總結(jié)之webpack常規(guī)打包優(yōu)化方案,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
vue給input file綁定函數(shù)獲取當(dāng)前上傳的對(duì)象完美實(shí)現(xiàn)方法
這篇文章主要介紹了vue給input file綁定函數(shù)獲取當(dāng)前上傳的對(duì)象完美實(shí)現(xiàn)方法,需要的朋友可以參考下2017-12-12vue3調(diào)度器effect的scheduler功能實(shí)現(xiàn)詳解
這篇文章主要為大家介紹了vue3調(diào)度器effect的scheduler功能實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12vue實(shí)現(xiàn)虛擬滾動(dòng)渲染成千上萬條數(shù)據(jù)
本文主要介紹了vue實(shí)現(xiàn)虛擬滾動(dòng)渲染成千上萬條數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02vue中循環(huán)請(qǐng)求接口參數(shù)問題及解決
這篇文章主要介紹了vue中循環(huán)請(qǐng)求接口參數(shù)問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08Element-Plus?el-col、el-row快速布局及使用方法
這篇文章主要介紹了Element-Plus?el-col、el-row快速布局及使用方法,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12Vue 利用指令實(shí)現(xiàn)禁止反復(fù)發(fā)送請(qǐng)求的兩種方法
這篇文章主要介紹了Vue 利用指令實(shí)現(xiàn)禁止反復(fù)發(fā)送請(qǐng)求的兩種方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09