Vue項目打包問題詳解(生產(chǎn)環(huán)境樣式失效)
前言
在公司項目發(fā)布上線后,出現(xiàn)了部分樣式失效的問題。我們引用的是vuetify第三方庫,經(jīng)過檢查,發(fā)現(xiàn)是部分樣式被vuetify自帶的css樣式給覆蓋,原因是生成環(huán)境的打包模式與開發(fā)環(huán)境不同。
打包模式的區(qū)別
- 生產(chǎn)模式(env.prod)
在生產(chǎn)模式下打包,項目會被最小化,所有的css代碼會被提取出來放在同一文件夾下(這也是上線后樣式出現(xiàn)問題的根本原因)
- 開發(fā)模式
開發(fā)模式打包并不會改變項目的層次結(jié)構(gòu),換句話說,我們在寫代碼過程中,頁面長啥樣,打包上線后就是原本的樣式,該模式下并不會改變代碼。但是該模式打包后的dist文件依舊比生產(chǎn)模式打包后的項目大很多。
案例

首先我們要知道為什么vuetify的樣式會覆蓋自定義樣式,因為自定義的樣式優(yōu)先級不夠高!在生產(chǎn)模式下,所有css代碼會被提取到一個文件夾下,而第三方庫的css一般會多個類名綁定(例如: .themelight .v-btn),如果自定義樣式只綁定一個類名(沒有在父類的作用域下),樣式優(yōu)先級不夠高,就會被覆蓋。
解決方案
- 方案一:配置vue.config.js文件
在
vue.config.js文件中將css的extract設(shè)置為false,生產(chǎn)環(huán)境打包默認(rèn)為true,這個選項會把css代碼提取到一個文件夾下。注意:開發(fā)環(huán)境的extract選項默認(rèn)為false
const webpack = require('webpack')
module.exports = {
css: {
extract: false
}
};
- 方案二:覆蓋第三方組件原有的類,或者加樣式穿透
當(dāng)我們想修改第三方組件的樣式時,可以選擇覆蓋其原有的類
<template>
<div class="button-box">
<v-btn>Submit</v-btn>
</div>
</template>
<style lang="sass" scoped>
.button-box
//v-btn是當(dāng)前組件已有的類,在這里設(shè)置屬性可以覆蓋原有的
.v-btn
color:#020202
</style>
也可使用
>>>來提升樣式優(yōu)先級,俗稱樣式穿透
<template>
<div class="button-box">
<v-btn class="submit-btn">Submit</v-btn>
</div>
</template>
<style lang="sass" scoped>
.button-box >>> .submit-btn
color: #020202
</style>
- 方案三:該方案用于解決緊急情況下需要發(fā)布上線(并不能縮小打包后的體積)
在.env.production文件中修改環(huán)境變量
// 本應(yīng)該是production,這里緊急解決問題,可改為develop,以開發(fā)環(huán)境的打包模式發(fā)布上線 NODE_ENV = 'develop'
總結(jié)
到此這篇關(guān)于Vue項目打包問題的文章就介紹到這了,更多相關(guān)Vue項目打包問題內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue2和Vue3在v-for遍歷時ref獲取dom節(jié)點的區(qū)別及說明
這篇文章主要介紹了Vue2和Vue3在v-for遍歷時ref獲取dom節(jié)點的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
使用el-form-item設(shè)置標(biāo)簽長度
這篇文章主要介紹了使用el-form-item設(shè)置標(biāo)簽長度方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
vue使用vue-json-viewer插件展示JSON格式數(shù)據(jù)的方法
這篇文章主要給大家介紹了關(guān)于vue使用vue-json-viewer插件展示JSON格式數(shù)據(jù)的相關(guān)資料,前端使用這個插件可以方便展現(xiàn)出json格式的數(shù)據(jù),下載引入使用代碼可直接使用,需要的朋友可以參考下2024-05-05

