溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Vue中樣式綁定是什么

發(fā)布時(shí)間:2020-08-27 13:47:48 來(lái)源:億速云 閱讀:155 作者:小新 欄目:web開(kāi)發(fā)

這篇文章給大家分享的是有關(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ò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI