欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何解決vue項目打包后文件過大問題

 更新時間:2022年04月13日 11:11:36   作者:Kuno_  
這篇文章主要介紹了如何解決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引入

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

盡可能把在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)文章

  • vue2安裝vue-router報錯的解決方法

    vue2安裝vue-router報錯的解決方法

    vue-router的安裝不是理想化的,會出現(xiàn)問題,需要靜下心認(rèn)真研究,熬過去就會懂得更多,這篇文章主要給大家介紹了關(guān)于vue2安裝vue-router報錯的解決方法,需要的朋友可以參考下
    2022-03-03
  • Vue3中的ref和reactive響應(yīng)式原理解析

    Vue3中的ref和reactive響應(yīng)式原理解析

    這篇文章主要介紹了Vue3中的ref和reactive響應(yīng)式,本節(jié)主要介紹了響應(yīng)式變量和對象,以及變量和對象在響應(yīng)式和非響應(yīng)式之間的轉(zhuǎn)換,需要的朋友可以參考下
    2022-08-08
  • Vue開發(fā)高德地圖應(yīng)用的最佳實踐

    Vue開發(fā)高德地圖應(yīng)用的最佳實踐

    要在Web頁面中加入地圖,我推薦你使用高德地圖,下面這篇文章主要給大家介紹了關(guān)于Vue開發(fā)高德地圖應(yīng)用的最佳實踐,需要的朋友可以參考下
    2021-07-07
  • vue 組件中slot插口的具體用法

    vue 組件中slot插口的具體用法

    這篇文章主要介紹了vue 中slot 的具體用法,包括子組件父組件的代碼介紹,需要的朋友可以參考下
    2018-04-04
  • 使用Vite2+Vue3渲染Markdown文檔的方法實踐

    使用Vite2+Vue3渲染Markdown文檔的方法實踐

    本文主要介紹了Vite2+Vue3渲染Markdown文檔的方法實踐,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的可以了解一下
    2021-08-08
  • vue3中provide和inject的使用

    vue3中provide和inject的使用

    provide和inject在Vue 2中已經(jīng)被廣泛應(yīng)用,不是新鮮API,3.0重新認(rèn)識一下它們兩個,本文重點給大家介紹vue3中provide和inject的使用,需要的朋友參考下吧
    2021-07-07
  • VUEJS實戰(zhàn)之構(gòu)建基礎(chǔ)并渲染出列表(1)

    VUEJS實戰(zhàn)之構(gòu)建基礎(chǔ)并渲染出列表(1)

    這篇文章主要為大家詳細(xì)介紹了VUEJS實戰(zhàn)之構(gòu)建基礎(chǔ)并渲染出列表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-06-06
  • Vite的createServer啟動源碼解析

    Vite的createServer啟動源碼解析

    這篇文章主要為大家介紹了Vite的createServer啟動源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • 詳解Vue3?父組件調(diào)用子組件方法($refs?在setup()、<script?setup>?中使用)

    詳解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-08
  • vue3原始值響應(yīng)方案及響應(yīng)丟失問題解讀

    vue3原始值響應(yīng)方案及響應(yīng)丟失問題解讀

    這篇文章主要介紹了vue3原始值響應(yīng)方案及響應(yīng)丟失問題解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04

最新評論