您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)Vue中樣式綁定是什么的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧。
Vue中的樣式綁定在網(wǎng)頁(yè)中的應(yīng)用比較廣泛,添加css樣式和刪除css樣式,用jq實(shí)現(xiàn)起來(lái)并不難,這次我們通過(guò)一個(gè)例子來(lái)攻克Vue中的css樣式綁定知識(shí)點(diǎn)。
效果:
在頁(yè)面上有一個(gè)文字“hello",點(diǎn)擊hello的時(shí)候,文字顏色變成紅色,再點(diǎn)擊,文字顏色又變成黑色。那么顏色的變化,我們需要通過(guò)css樣式來(lái)控制。
方法1:
<div id="root" @click='handleClick' :class='{actived:isActived}'> Hello World </div> <script> // 父組件 new Vue({ el:"#root", data:{ isActived:false, }, methods:{ handleClick:function(){ this.isActived=!this.isActived; } } }) </script> <style> .actived{ color: red; } </style>
解釋下這個(gè)寫(xiě)法:class='{actived:isActived}',如果isActived是false,則class='',如果isActived是true,則class='actived'。
所以我們?cè)赿ata中定義了默認(rèn)值false,當(dāng)點(diǎn)擊的時(shí)候會(huì)觸發(fā)方法handleClick,使this.isActived等于取反的值。
方法2:
<div id="root" @click='handleClick' :class='[isActived]'> Hello World </div> <script> // 父組件 new Vue({ el:"#root", data:{ isActived:'', }, methods:{ handleClick:function(){ this.isActived=this.isActived===''?'actived':''; } } }) </script> <style> .actived{ color: red; } </style>
這種方法我們是給了一個(gè)數(shù)組,數(shù)組中傳遞一個(gè)默認(rèn)的空值isActived,當(dāng)鼠標(biāo)點(diǎn)擊的時(shí)候,就會(huì)觸發(fā)handleClick方法,在這里我們通過(guò)三元運(yùn)算符來(lái)獲取this.isActived的值。
和三元運(yùn)算符同樣效果的就是用if判斷:
if(this.isActived==''){ this.isActived='actived'; }else{ this.isActived=''; }
方法3:
在上面我們是直接用class來(lái)實(shí)現(xiàn)效果,那么html中style樣式如何實(shí)現(xiàn)呢?代碼并不難,我們可以仿照第二個(gè)來(lái)試試效果:
<div id="root" @click='handleClick' :style='styleObj'> Hello World </div> <script> // 父組件 new Vue({ el:"#root", data:{ styleObj:{ color:'black' }, }, methods:{ handleClick:function(){ this.styleObj.color=this.styleObj.color==='black'?'red':'black'; } } }) </script>
我們默認(rèn)給出一個(gè)黑色的字體顏色black,點(diǎn)頁(yè)面文字被點(diǎn)擊后,觸發(fā)函數(shù)handleClick,這個(gè)時(shí)候我們?nèi)匀挥萌\(yùn)算符判斷獲取到this.styleObj.color的值來(lái)實(shí)現(xiàn)效果。
感謝各位的閱讀!關(guān)于Vue中樣式綁定是什么就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。