如何解決vue項目打包后文件過大問題
為什么打包后文件過大?
移動app項目,使用vue-cli腳手架搭建,UI主要運(yùn)用的是Muse-UI,開發(fā)過程中為滿足需求,混入Element-UI部分組件,加之團(tuán)隊開發(fā),前端不止一人參與,在沒有統(tǒng)一規(guī)范約束的情況下,編碼風(fēng)格和方式都很迥異和…混亂,以致依賴過多,打包時webpack把所有的庫都打包在一起,所以vendor.js文件和app.js文件很大,最后出現(xiàn)進(jìn)入首個頁面時會長時間的白屏,影響用戶體驗。
如何快速解決
在優(yōu)化復(fù)雜性項目時,只增不減可大大減少風(fēng)險,bug可控,既保證項目正常運(yùn)行同時減少不必要的工作量
1.路由懶加載【使用es6提案的import()方式】
這里推薦使用es提案的import()方式是因為未修改前路由定義時也時用import的方式引用,若使用vue路由懶加載組件,修改的地方較多,不夠快捷。
修改后引用方式如圖,即:
把import login from '@/views/login/login'修改為
const login = () => import('@/views/login/login')
其他路由配置不需要變動。
2.CDN引入
在 index.html 頁面 使用cdn加載依賴
<link rel="stylesheet" rel="external nofollow" > <script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script> <script src="https://cdn.bootcss.com/vue/2.5.15/vue.min.js"></script> <link rel="stylesheet" rel="external nofollow" > <link rel="external nofollow" rel="stylesheet"> <script src="https://cdn.bootcss.com/jquery/3.1.0/jquery.js"></script> <script src="https://cdn.bootcss.com/echarts/4.2.1-rc1/echarts.js"></script> <script src="https://cdn.bootcss.com/qs/6.5.2/qs.min.js"></script> <script src="https://cdn.bootcss.com/element-ui/2.0.7/index.js"></script> <script src="https://unpkg.com/axios/dist/axios.min.js"></script> <script src="https://unpkg.com/muse-ui/dist/muse-ui.js"></script> <script src="https://cdn.bootcss.com/exif-js/2.3.0/exif.js"></script>
添加 webpack.base.conf.js 配置
externals: { 'element-ui': 'ELEMENT', 'vue': 'Vue', 'querystring':'Qs', 'vue-router': 'VueRouter', 'MuseUI': 'MuseUI', 'axios':'axios', 'jquery': "jQuery", "EXIF":'EXIF', 'echarts': 'echarts' },
盡可能把在main.js中的引用的依賴用cdn在index.html中引用
在開源項目 CDN 加速服務(wù)中可以查找到大部分開源庫的cdn
這里是不建議在優(yōu)化已成型項目時直接把main.js中依賴引用部分刪掉,如果刪掉需要在公共JS中重新引入或者在所需依賴頁面中導(dǎo)入,還要注意導(dǎo)入時定義的名稱需要跟項目中已存在的依賴引用變量名一致,這將加大自己的工作量,新搭建項目或者想深入學(xué)習(xí)讓代碼更純凈者可以去度娘找資料研究哦
這樣優(yōu)化就告一段落了,打包后文件大小如下:
vendor.***文件大小從1.98M減少至342K
app.***文件大小從573K減少至53.3K
頁面加載速度:
進(jìn)入首個頁面時長從平均13.6S減少至平均1.12S,近乎秒進(jìn)。
最后對項目使用的圖片素材進(jìn)行壓縮處理,修改config/index.js productionSourceMap: false 去除打包時生產(chǎn).map文件,加快打包速度
以上是我在處理Vue項目打包后文件過大這個問題時的解決方法,希望能幫到大家,也希望大家多多支持腳本之家。
相關(guān)文章
Vue3中的ref和reactive響應(yīng)式原理解析
這篇文章主要介紹了Vue3中的ref和reactive響應(yīng)式,本節(jié)主要介紹了響應(yīng)式變量和對象,以及變量和對象在響應(yīng)式和非響應(yīng)式之間的轉(zhuǎn)換,需要的朋友可以參考下2022-08-08VUEJS實戰(zhàn)之構(gòu)建基礎(chǔ)并渲染出列表(1)
這篇文章主要為大家詳細(xì)介紹了VUEJS實戰(zhàn)之構(gòu)建基礎(chǔ)并渲染出列表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-06-06詳解Vue3?父組件調(diào)用子組件方法($refs?在setup()、<script?setup>?中使用)
這篇文章主要介紹了Vue3?父組件調(diào)用子組件方法($refs?在setup()、<script?setup>?中使用),在 vue2 中 ref 被用來獲取對應(yīng)的子元素,然后調(diào)用子元素內(nèi)部的方法,本文通過實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08vue3原始值響應(yīng)方案及響應(yīng)丟失問題解讀
這篇文章主要介紹了vue3原始值響應(yīng)方案及響應(yīng)丟失問題解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04