Vue.js樣式動(dòng)態(tài)綁定實(shí)現(xiàn)小結(jié)
在項(xiàng)目中,我們時(shí)常會(huì)遇到動(dòng)態(tài)的去綁定操作切換不同的CSS樣式,結(jié)合自身項(xiàng)目中遇到的一些情況,也參考了一些文檔,針對(duì)vue.js樣式的動(dòng)態(tài)綁定切換做出如下小結(jié):
動(dòng)態(tài)切換的核心思想:
利用vue指令v-bind來(lái)實(shí)現(xiàn)動(dòng)態(tài)綁定,從而設(shè)置切換不同的樣式~
vue的最大特點(diǎn)是數(shù)據(jù)驅(qū)動(dòng),利用特殊的語(yǔ)法將DOM“綁定”到底層數(shù)據(jù),DOM與數(shù)據(jù)保持同步,每當(dāng)數(shù)據(jù)發(fā)生變化,DOM視圖就會(huì)做出相應(yīng)的更新和響應(yīng),正是基于這種特性,我們得以實(shí)現(xiàn)class和style的動(dòng)態(tài)綁定~
(一定要充分理解數(shù)據(jù)驅(qū)動(dòng)的含義,共勉~)
特別說(shuō)明:
1. v-bind在處理class和style時(shí),專(zhuān)門(mén)增強(qiáng)了它。表達(dá)式的結(jié)果類(lèi)型不僅可以是字符串,還可以是對(duì)象和數(shù)組。
v-bind用于綁定屬性和數(shù)據(jù) ,其縮寫(xiě)為“ : ” 也就是v-bind:id === :id 。
根據(jù)不同的項(xiàng)目需求和不同的實(shí)現(xiàn)思路,現(xiàn)初步總結(jié)了如下方法:
(歡迎小伙伴們補(bǔ)充添加,一起進(jìn)步~~)
class屬性綁定
1. 三目元算符方式:
<!--vue代碼-->
<ul>
<li v-for="item in itemData" :key="item">
<i :class="item.isA ? 'class_a' : 'class_b'"></i>
</li>
</ul>
<!-- CSS代碼 -->
.class_a,.class_b{
/*這里可以寫(xiě)一些公共樣式*/
}
.class_a{
/*這里寫(xiě)需要設(shè)置的第一種樣式*/
}
.class_b{
/*這里寫(xiě)需要設(shè)置的第二種樣式*/
}
2. 基本綁定:
<!--vue代碼-->
<div :class="{class_a:isActive}"></div>
<!-- 博主在這里用vue-cli做例子,小伙伴們注意與vue的區(qū)別 -->
export default {
name: "test1",
data(){
return{
isActive:true
}
}
}
<!-- CSS代碼 -->
.class_a{
/*這里寫(xiě)需要設(shè)置的樣式*/
}
以上可以根據(jù)isACtive的值,動(dòng)態(tài)判斷來(lái)進(jìn)行class樣式的綁定。
特別說(shuō)明:
1. vue 的分隔符默認(rèn)是 {{ }}, 在分隔符里面的字符串會(huì)被認(rèn)為是數(shù)據(jù)變量,可以通過(guò) class="{{ className }}" 方式設(shè)置class,但是vue不推薦這種方式與 v-bind:class 的方式混用,二者只能選其一。
2. v-bind:class 雖然與class屬性里綁定變量的方式不能共存,卻可以與原生的class特性共存,即 一個(gè)DOM標(biāo)簽中允許同時(shí)出現(xiàn)原生class和v-bind:class。
3. 為了避免不必要的問(wèn)題,要寫(xiě)在data中的值盡量不要用中劃線(xiàn),可以采用下劃線(xiàn)~如果data中用中劃線(xiàn)的話(huà),需要加單引號(hào),否則出錯(cuò),而且,在v-bind中使用時(shí),也需要加單引號(hào)。加上單引號(hào)又無(wú)法識(shí)別數(shù)據(jù),默認(rèn)為true。
3. 可以傳入多個(gè)屬性動(dòng)態(tài)切換多個(gè)class
<!--vue代碼--> <div :class="{class_a:isActive,class_b:isActive_b}"></div>
4. 對(duì)象綁定
<!--vue代碼-->
<div :class="classObject"></div>
<!-- 博主在這里用vue-cli做例子,小伙伴們注意與vue的區(qū)別 -->
export default {
name: "test1",
data(){
return{
classObject:{
class_a:true,
class_b:true
}
}
}
}
<!-- CSS代碼 -->
.class_a{
/*這里寫(xiě)需要設(shè)置的第一種樣式*/
}
.class_b{
/*這里寫(xiě)需要設(shè)置的第二種樣式*/
}
特別說(shuō)明:
這里v-bind直接利用對(duì)象進(jìn)行綁定,需注意對(duì)象中的鍵名應(yīng)與class樣式名保持一致。
5. 數(shù)組綁定
數(shù)組里的變量改變時(shí),動(dòng)態(tài)更新class列表
<!--vue代碼-->
<div :class="[classA,classB]"></div>
<!-- 博主在這里用vue-cli做例子,小伙伴們注意與vue的區(qū)別 -->
export default {
name: "test1",
data(){
return{
classA:'class_a',
classB:'class_b'
}
}
}
<!-- CSS代碼 -->
.class_a{
/*這里寫(xiě)需要設(shè)置的第一種樣式*/
}
.class_b{
/*這里寫(xiě)需要設(shè)置的第二種樣式*/
}
6. 綁定返回對(duì)象的計(jì)算屬性
強(qiáng)大且常用的模式~
<!--vue代碼-->
<div v-bind="classObject"></div>
<!-- 博主在這里用vue-cli做例子,小伙伴們注意與vue的區(qū)別 -->
export default {
name: "test1",
data(){
return{
isActive:true
}
},
computed:{
classObject:function () {
return{
class_a:this.isActive,
class_b:!this.isActive
// 這里要結(jié)合自身項(xiàng)目情況修改填寫(xiě)
}
}
}
}
<!-- CSS代碼 -->
.class_a{
/*這里寫(xiě)需要設(shè)置的第一種樣式*/
}
.class_b{
/*這里寫(xiě)需要設(shè)置的第二種樣式*/
}
style屬性綁定(內(nèi)聯(lián))
1. 直接設(shè)置樣式
<!--vue代碼-->
<div :style="color:selectedColor,fontsize:fontSize + 'px'"></div>
<!-- 博主在這里用vue-cli做例子,小伙伴們注意與vue的區(qū)別 -->
export default {
name: "test1",
data(){
return{
selectedColor:pink,
fontSize:20
// 注意前后名稱(chēng)的一致性
}
}
}
2. 也可以使用對(duì)象
(可以參照上述class)
<!--vue代碼-->
<div :style="styleObject"></div>
<!-- 博主在這里用vue-cli做例子,小伙伴們注意與vue的區(qū)別 -->
export default {
name: "test1",
data(){
return{
styleObject{
selectedColor:pink,
fontSize:20
}
}
}
}
3. 使用數(shù)組
<!--vue代碼-->
<div :style="[styleA,styleB]"></div>
<!-- 博主在這里用vue-cli做例子,小伙伴們注意與vue的區(qū)別 -->
export default {
name: "test1",
data(){
return{
styleA:{
color:'red',
fontSize: '30px'
},
styleB:{
color:'green',
fontSize: '15px'
},
}
}
}
小伙伴們可根據(jù)上述方法結(jié)合自身項(xiàng)目情況修改調(diào)用,如有問(wèn)題,歡迎交流
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue-model實(shí)現(xiàn)簡(jiǎn)易計(jì)算器
這篇文章主要為大家詳細(xì)介紹了vue-model實(shí)現(xiàn)簡(jiǎn)易計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08
vue2+element-ui+nodejs實(shí)現(xiàn)圖片上傳和修改圖片到數(shù)據(jù)庫(kù)的方法
在Web開(kāi)發(fā)中經(jīng)常需要使用圖片,有時(shí)候需要對(duì)圖片進(jìn)行上傳,這篇文章主要給大家介紹了關(guān)于vue2+element-ui+nodejs實(shí)現(xiàn)圖片上傳和修改圖片到數(shù)據(jù)庫(kù)的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04
vue + typescript + video.js實(shí)現(xiàn) 流媒體播放 視頻監(jiān)控功能
視頻才用流媒體,有后臺(tái)實(shí)時(shí)返回?cái)?shù)據(jù), 要支持flash播放, 所以需安裝對(duì)應(yīng)的flash插件。這篇文章主要介紹了vue + typescript + video.js 流媒體播放 視頻監(jiān)控,需要的朋友可以參考下2019-07-07
vue中關(guān)于template報(bào)錯(cuò)等問(wèn)題的解決
這篇文章主要介紹了vue中關(guān)于template報(bào)錯(cuò)等問(wèn)題的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
ElementUI表單驗(yàn)證validate和validateField的使用及區(qū)別
Element-UI作為前端框架,最常使用到的就是表單驗(yàn)證,下面這篇文章主要給大家介紹了關(guān)于ElementUI表單驗(yàn)證validate和validateField的使用及區(qū)別,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
實(shí)用的 vue tags 創(chuàng)建緩存導(dǎo)航的過(guò)程實(shí)現(xiàn)
這篇文章主要介紹了實(shí)用的 vue tags 創(chuàng)建緩存導(dǎo)航的過(guò)程實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
vue中如何使用embed標(biāo)簽PDF預(yù)覽
這篇文章主要介紹了vue中如何使用embed標(biāo)簽PDF預(yù)覽,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05
Vue 數(shù)值改變頁(yè)面沒(méi)有刷新的問(wèn)題解決(數(shù)據(jù)改變視圖不更新的問(wèn)題)
這篇文章主要介紹了Vue 數(shù)值改變頁(yè)面沒(méi)有刷新的問(wèn)題解決(數(shù)據(jù)改變視圖不更新的問(wèn)題),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09

