Vue項目中打包優(yōu)化的四種方法詳解
前言
默認情況下,通過import語法導(dǎo)入的第三方依賴包,最終會全部打包到一個js文件中,會導(dǎo)致單文件體積過大大,在網(wǎng)速底下時會阻塞網(wǎng)頁加載,影響用戶體驗。
打包優(yōu)化的目的:
1、項目啟動速度,和性能
2、必要的清理數(shù)據(jù)
3、減少打包后的體積
第一點是核心,第二點呢其實主要是清理console
性能優(yōu)化的主要方向:
路由懶加載
去除生產(chǎn)版console.log的打印輸出
開發(fā)版使用依賴項,生產(chǎn)版使用在線CDN
項目打包及配置
1.異步組件配置(路由懶加載)
一上來加載所有的組件, 首屏加載就比較慢, 可以配置路由按需加載
當(dāng)打包構(gòu)建項目時,js包會變得非常大,影響頁面加載,我們把不同路由的對應(yīng)組件分割成不同的代碼塊,然后當(dāng)路由被訪問的時候加載對應(yīng)的組件,這樣能提升訪問效率。
切分之后,并不是瀏覽器訪問某個路由,才去下載對應(yīng)的模塊,仍然在首次訪問程序時,下載所有模塊,只不過每個模塊分的很小,加載首頁時需要的模塊能夠更快的下載下來,所以能夠更快的顯示
具體分三步:
- 安裝包 npm install --save-dev @babel/plugin-syntax-dynamic-impor
- 在babel.config.js配置文件中加入插件
- 將路由改為按需加載的形式
import Vue from 'vue' import VueRouter from 'vue-router' Vue.use(VueRouter) const routes = [ { path: '/Login', name: 'Login', // 路由懶加載 component: () => import('../views/Login/index.vue') }, { path: '/', component: () => import('../views/layout/index.vue'), children: [ { path: '', component: () => import('../views/Home/index.vue') } ] } ] //或者如下 const Login = () => import('@/views/Login') const Reg = () => import('@/views/Reg') const Layout = () => import('@/views/Layout')
2.去掉打包后的 console
打包上線后的console語句沒有任何作用,所以我們應(yīng)該移除它,除去手動移除,還可以使用插件的方式來移除代碼里的console語句。
安裝依賴 : yarn add terser-webpack-plugin -D (npm i terser-webpack-plugin -D)
在vue.config.js修改配置文件
// 獲取當(dāng)前的打包環(huán)境(具體文章最后會說明) const env = process.env.NODE_ENV // 覆蓋默認的webpack配置 module.exports = { publicPath: './', //首次加載白屏(打包后文件路徑問題) devServer: { port: 3000, open: true }, chainWebpack: (config) => { config.optimization.minimizer('terser').tap((args) => { args[0].terserOptions.compress.drop_console = true return args }) } }
3.使用CDN
使用CDN,減少包的體積。 將線上環(huán)境中用到的一些依賴,使用CDN網(wǎng)絡(luò)節(jié)點的方式進行引用,而不是直接打包到包里。
項目開發(fā)階段和生產(chǎn)階段不一樣,我們在開發(fā)階段還是要使用import導(dǎo)入依賴的方式來進行開發(fā),在生產(chǎn)階段再配置CDN外鏈來獲取項目依賴。
默認情況下,Vue項目的開發(fā)模式和發(fā)布模式,共同使用一個打包的入口文件(src/main.js)為了將項目的開發(fā)過程與發(fā)布過程分離,我們可以分別使用兩個入口文件,一個用于開發(fā)環(huán)境打包(這個就是main.js),一個用于生產(chǎn)環(huán)境打包
在vue.config.js中
// 是否為生產(chǎn)環(huán)境 const isProduction = process.env.NODE_ENV !== 'development'; // 本地環(huán)境是否需要使用cdn const devNeedCdn = false // cdn鏈接 const cdn = { // cdn:模塊名稱和模塊作用域命名(對應(yīng)window里面掛載的變量名稱) externals: { vue: 'Vue', vuex: 'Vuex', 'vue-router': 'VueRouter', 'marked': 'marked', 'highlight.js': 'hljs', 'nprogress': 'NProgress', 'axios': 'axios' }, // cdn的css鏈接 css: [ ], // cdn的js鏈接 js: [ 'https://cdn.bootcss.com/vue/2.6.10/vue.min.js', 'https://cdn.bootcss.com/vuex/3.1.2/vuex.min.js', 'https://cdn.bootcss.com/vue-router/3.1.3/vue-router.min.js', 'https://cdn.bootcss.com/axios/0.19.2/axios.min.js' ] } module.exports = { chainWebpack: config => { // ============注入cdn start============ config.plugin('html').tap(args => { // 生產(chǎn)環(huán)境或本地需要cdn時,才注入cdn if (isProduction || devNeedCdn) args[0].cdn = cdn return args }) // ============注入cdn start============ }, configureWebpack: config => { // 用cdn方式引入,則構(gòu)建時要忽略相關(guān)資源 if (isProduction || devNeedCdn) config.externals = cdn.externals } }
<!-- 使用CDN的CSS文件 --> <% for (var i in htmlWebpackPlugin.options.cdn && htmlWebpackPlugin.options.cdn.css) { %> <link href="<%= htmlWebpackPlugin.options.cdn.css[i] %>" rel="external nofollow" rel="stylesheet" /> <% } %> <!-- 使用CDN的CSS文件 --> <!-- 使用CDN的JS文件 --> <% for (var i in htmlWebpackPlugin.options.cdn && htmlWebpackPlugin.options.cdn.js) { %> <script src="<%= htmlWebpackPlugin.options.cdn.js[i] %>"></script> <% } %> <!-- 使用CDN的JS文件 -->
4.yarn build生成dist目錄
得到一個dist目錄,這個目錄包含了項目中所有的頁面,樣式,業(yè)務(wù), 第三方包, 默認html文件中引入了資源文件是以項目根目錄引入的, 雙擊目前是打開不了的 可以 借助vscode中的live-sever
打包的過程中, 會對代碼進行壓縮合并, 版本降級, 語法轉(zhuǎn)換等...
module.exports = { publicPath: './', //解決路徑問題 devServer: { port: 3000, //改變端口號 open: true //運行后,自動打開瀏覽器運行 } }
總結(jié)
到此這篇關(guān)于Vue項目中打包優(yōu)化的四種方法的文章就介紹到這了,更多相關(guān)Vue項目打包優(yōu)化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決vue刷新頁面以后丟失store的數(shù)據(jù)問題
這篇文章主要介紹了解決vue刷新頁面以后丟失store的數(shù)據(jù)問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08vite+vue3中require?is?not?defined問題及解決
這篇文章主要介紹了vite+vue3中require?is?not?defined問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05element-plus+Vue3實現(xiàn)表格數(shù)據(jù)動態(tài)渲染
在Vue中,el-table是element-ui提供的強大表格組件,可以用于展示靜態(tài)和動態(tài)表格數(shù)據(jù),本文主要介紹了element-plus+Vue3實現(xiàn)表格數(shù)據(jù)動態(tài)渲染,感興趣的可以了解一下2024-03-03解決vue 使用setTimeout,離開當(dāng)前路由setTimeout未銷毀的問題
這篇文章主要介紹了解決vue 使用setTimeout,離開當(dāng)前路由setTimeout未銷毀的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07