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