Vue項(xiàng)目中打包優(yōu)化的四種方法詳解
前言
默認(rèn)情況下,通過(guò)import語(yǔ)法導(dǎo)入的第三方依賴包,最終會(huì)全部打包到一個(gè)js文件中,會(huì)導(dǎo)致單文件體積過(guò)大大,在網(wǎng)速底下時(shí)會(huì)阻塞網(wǎng)頁(yè)加載,影響用戶體驗(yàn)。
打包優(yōu)化的目的:
1、項(xiàng)目啟動(dòng)速度,和性能
2、必要的清理數(shù)據(jù)
3、減少打包后的體積
第一點(diǎn)是核心,第二點(diǎn)呢其實(shí)主要是清理console
性能優(yōu)化的主要方向:
路由懶加載
去除生產(chǎn)版console.log的打印輸出
開(kāi)發(fā)版使用依賴項(xiàng),生產(chǎn)版使用在線CDN
項(xiàng)目打包及配置
1.異步組件配置(路由懶加載)
一上來(lái)加載所有的組件, 首屏加載就比較慢, 可以配置路由按需加載
當(dāng)打包構(gòu)建項(xiàng)目時(shí),js包會(huì)變得非常大,影響頁(yè)面加載,我們把不同路由的對(duì)應(yīng)組件分割成不同的代碼塊,然后當(dāng)路由被訪問(wèn)的時(shí)候加載對(duì)應(yīng)的組件,這樣能提升訪問(wèn)效率。
切分之后,并不是瀏覽器訪問(wèn)某個(gè)路由,才去下載對(duì)應(yīng)的模塊,仍然在首次訪問(wèn)程序時(shí),下載所有模塊,只不過(guò)每個(gè)模塊分的很小,加載首頁(yè)時(shí)需要的模塊能夠更快的下載下來(lái),所以能夠更快的顯示
具體分三步:
- 安裝包 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ǔ)句沒(méi)有任何作用,所以我們應(yīng)該移除它,除去手動(dòng)移除,還可以使用插件的方式來(lái)移除代碼里的console語(yǔ)句。
安裝依賴 : yarn add terser-webpack-plugin -D (npm i terser-webpack-plugin -D)
在vue.config.js修改配置文件
// 獲取當(dāng)前的打包環(huán)境(具體文章最后會(huì)說(shuō)明)
const env = process.env.NODE_ENV
// 覆蓋默認(rèn)的webpack配置
module.exports = {
publicPath: './', //首次加載白屏(打包后文件路徑問(wèn)題)
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é)點(diǎn)的方式進(jìn)行引用,而不是直接打包到包里。
項(xiàng)目開(kāi)發(fā)階段和生產(chǎn)階段不一樣,我們?cè)陂_(kāi)發(fā)階段還是要使用import導(dǎo)入依賴的方式來(lái)進(jìn)行開(kāi)發(fā),在生產(chǎn)階段再配置CDN外鏈來(lái)獲取項(xiàng)目依賴。
默認(rèn)情況下,Vue項(xiàng)目的開(kāi)發(fā)模式和發(fā)布模式,共同使用一個(gè)打包的入口文件(src/main.js)為了將項(xiàng)目的開(kāi)發(fā)過(guò)程與發(fā)布過(guò)程分離,我們可以分別使用兩個(gè)入口文件,一個(gè)用于開(kāi)發(fā)環(huán)境打包(這個(gè)就是main.js),一個(gè)用于生產(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:模塊名稱和模塊作用域命名(對(duì)應(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時(shí),才注入cdn
if (isProduction || devNeedCdn) args[0].cdn = cdn
return args
})
// ============注入cdn start============
},
configureWebpack: config => {
// 用cdn方式引入,則構(gòu)建時(shí)要忽略相關(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目錄
得到一個(gè)dist目錄,這個(gè)目錄包含了項(xiàng)目中所有的頁(yè)面,樣式,業(yè)務(wù), 第三方包, 默認(rèn)html文件中引入了資源文件是以項(xiàng)目根目錄引入的, 雙擊目前是打開(kāi)不了的 可以 借助vscode中的live-sever
打包的過(guò)程中, 會(huì)對(duì)代碼進(jìn)行壓縮合并, 版本降級(jí), 語(yǔ)法轉(zhuǎn)換等...
module.exports = {
publicPath: './', //解決路徑問(wèn)題
devServer: {
port: 3000, //改變端口號(hào)
open: true //運(yùn)行后,自動(dòng)打開(kāi)瀏覽器運(yùn)行
}
}
總結(jié)
到此這篇關(guān)于Vue項(xiàng)目中打包優(yōu)化的四種方法的文章就介紹到這了,更多相關(guān)Vue項(xiàng)目打包優(yōu)化內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue實(shí)現(xiàn)滾動(dòng)條下滑時(shí)隱藏導(dǎo)航欄,上滑時(shí)顯示導(dǎo)航欄功能
這篇文章主要介紹了vue實(shí)現(xiàn)滾動(dòng)條下滑時(shí)隱藏導(dǎo)航欄,上滑時(shí)顯示導(dǎo)航欄,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-07-07
vue中使用element ui的input框?qū)崿F(xiàn)模糊搜索的輸入框
這篇文章主要介紹了vue中使用element ui的input框?qū)崿F(xiàn)模糊搜索的輸入框,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-11-11
前端Vue頁(yè)面中展示本地圖片簡(jiǎn)單代碼示例
今天遇到一個(gè)在vue文件中引入本地圖片的問(wèn)題,于是有了這篇文章,本文主要給大家介紹了關(guān)于前端Vue頁(yè)面中展示本地圖片的相關(guān)資料,需要的朋友可以參考下2023-12-12
利用nodeJS+vue圖片上傳實(shí)現(xiàn)更新頭像的過(guò)程
Vue是一套構(gòu)建用戶界面的框架,最近工作中遇到了一個(gè)需求,需要做一個(gè)更新頭像的通能,下面這篇文章主要給大家介紹了關(guān)于利用nodeJS+vue圖片上傳的相關(guān)資料,需要的朋友可以參考下2022-04-04
vue2.0 實(shí)現(xiàn)頁(yè)面導(dǎo)航提示引導(dǎo)的方法
下面小編就為大家分享一篇vue2.0 實(shí)現(xiàn)頁(yè)面導(dǎo)航提示引導(dǎo)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
vue根據(jù)進(jìn)入的路由進(jìn)行原路返回的方法
今天小編就為大家分享一篇vue根據(jù)進(jìn)入的路由進(jìn)行原路返回的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09

