溫馨提示×

溫馨提示×

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

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

Vue動(dòng)態(tài)樣式綁定的方法是什么

發(fā)布時(shí)間:2023-04-07 09:44:46 來源:億速云 閱讀:109 作者:iii 欄目:開發(fā)技術(shù)

本文小編為大家詳細(xì)介紹“Vue動(dòng)態(tài)樣式綁定的方法是什么”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Vue動(dòng)態(tài)樣式綁定的方法是什么”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。

    解釋

    操作元素的 class 列表和內(nèi)聯(lián)樣式是數(shù)據(jù)綁定的一個(gè)常見需求。因?yàn)樗鼈兌际菍傩裕晕覀兛梢杂?v-bind 處理它們:只需要通過表達(dá)式計(jì)算出字符串結(jié)果即可。不過,字符串拼接麻煩且易錯(cuò)。因此,在將 v-bind 用于 class 和 style 時(shí),Vue.js 做了專門的增強(qiáng)。表達(dá)式結(jié)果的類型除了字符串之外,還可以是對象或數(shù)組。 ---- 官方定義

    通過 v-bind 指令給 DOM 元素動(dòng)態(tài)綁定 Class 和 Style,一般用于根據(jù)不同數(shù)據(jù)狀態(tài)切換元素樣式的場景下。

    綁定元素的 Class

    我們可以通過數(shù)組和對象的兩種形式綁定元素的 Class。

    1 對象

    1.1 對象語法

    通過傳給 v-bind:class 一個(gè)對象,以動(dòng)態(tài)地切換 class:

    <div v-bind:class="{ show: isShow }"></div>

    代碼解釋:

    上面的語法表示 show 這個(gè) class 存在與否將取決于數(shù)據(jù)屬性 isShow 是否為真值。

    具體示例:

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>Document</title>
    </head>
    <style>.hide {
        display: none;
      }</style>
    <body>
      <div id="app"> 
        <div v-bind:class="{hide: isHide}">Hello !</div>
      </div>
    </body>
    <script src="https://unpkg.com/vue/dist/vue.js"></script>
    <script>var vm = new Vue({
    	el: '#app',
      data: {
      	isHide: true
      },
    })
    //vm.isHide = true</script>
    </html>

    代碼解釋:

    HTML 代碼第 2 行,我們給 div 綁定來樣式,當(dāng) isHide 為真值時(shí), 其渲染結(jié)果為 <div class="hide"></div>,否則 <div></div>。
    打開控制臺(tái),修改 vm.isHide 的值可以動(dòng)態(tài)改變頁面效果。

    1.2 與普通的 class 屬性共存

    此外,v-bind:class 指令也可以與普通的 class 屬性共存。

    語法:<div class ="defaultClass" v-bind:class="{ classA: isA,classB:isB }">

    當(dāng)有如下模板:

    <div
      class="defaultClass"
      v-bind:class="{ show: isShow, 'text-danger': hasError }"
    ></div>

    和如下 data:

    data: {
      isShow: true,
      hasError: false
    }

    結(jié)果渲染為:

    <div class="defaultClass active"></div>

    代碼解釋:

    當(dāng) isShow 或者 hasError 變化時(shí),class 列表將相應(yīng)地更新。

    例如,如果 hasError 的值為 true,isShow 的值為 true,class 列表將變?yōu)?nbsp;"defaultClass show text-danger"。

    例如,如果 hasError 的值為 trueisShow 的值為 false,class 列表將變?yōu)?nbsp;"defaultClass text-danger"。

    在之前介紹的案例中,我們將綁定的數(shù)據(jù)對象內(nèi)聯(lián)定義在模板里, 這樣顯得比較繁瑣。其實(shí),我們可以統(tǒng)一定義在一個(gè)c lassObject 中:

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>Document</title>
    </head>
    <body>
      <div id="app"> 
        <div class="defaultClass" v-bind:class="classObject">Hello !</div>
      </div>
    </body>
    <script src="https://unpkg.com/vue/dist/vue.js"></script>
    <script>var vm = new Vue({
    	el: '#app',
      data: {
      	classObject: {
          show: true,
          'text-danger': false
        }
      },
    })</script>
    </html>

    結(jié)果渲染為:

    <div class="defaultClass show"></div>

    代碼解釋:

    HTML 代碼中,我們首先給 div 一個(gè)固定樣式 defaultClass, 然后通過 classObject 給 div 綁定樣式。

    JS 代碼 第 6-9 行,我們定義了數(shù)據(jù) classObject,它有兩個(gè)屬性:1. 屬性 show,值為 true,2. 屬性 text-danger,值為 false。所以,最后頁面渲染的效果是:<div class="defaultClass show"></div>

    1.3 利用計(jì)算屬性綁定樣式
    <div v-bind:class="classObject"></div>

    我們也可以在這里綁定一個(gè)返回對象的 計(jì)算屬性 。這是一個(gè)常用且強(qiáng)大的模式:

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>Document</title>
    </head>
    <body>
      <div id="app"> 
        <div v-bind:class="classObject"></div>
      </div>
    </body>
    <script src="https://unpkg.com/vue/dist/vue.js"></script>
    <script>var vm = new Vue({
    	el: '#app',
      computed: {
        classObject: function () {
          return {
            show: true,
            'text-danger': false
          }
        }
      }
    })</script>
    </html>

    結(jié)果渲染為:

    <div class="defaultClass show"></div>

    代碼解釋:

    HTML 代碼中,我們通過 classObject 給 div 綁定樣式。

    JS 代碼 第 6-11 行,我們定義了計(jì)算屬性 classObject,它返回一個(gè)對象,該對象有兩個(gè)屬性:1. 屬性 show,值為 true,2. 屬性 text-danger,值為 false。所以,最后頁面渲染的效果是:<div class="show"></div>

    2 數(shù)組語法

    我們可以把一個(gè)數(shù)組傳給 v-bind:class,以應(yīng)用一個(gè) class 列表:

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>Document</title>
    </head>
    <body>
      <div id="app"> 
        <div v-bind:class="[classA, classB]">Hello !</div>
      </div>
    </body>
    <script src="https://unpkg.com/vue/dist/vue.js"></script>
    <script>var vm = new Vue({
    	el: '#app',
      data: {
      	classA: 'classA',
        classB: 'classB1 classB2'
      },
    })</script>
    </html>

    渲染為:

    <div class="classA classB1 classB2"></div>

    代碼解釋:

    在 HTML 代碼中,我們通過數(shù)組給 div 綁定樣式,數(shù)組中有 classA 和 classB 兩個(gè)值。

    在 JS 代碼第 6-7 行定義了 classA 和 classB 兩個(gè)字符串,它的格式和元素 class 的格式相同,不同的樣式類之間以空格相隔。

    如果你也想根據(jù)條件切換列表中的 class,可以用三元表達(dá)式:

    <div v-bind:class="[isShow ? showClass : '', classB]"></div>

    這樣寫將始終添加 classB 的樣式,但是只有在 isShow 為真時(shí)才添加 showClass

    不過,當(dāng)有多個(gè)條件 class 時(shí)這樣寫有些繁瑣。所以在數(shù)組語法中也可以使用對象的形式來表達(dá)數(shù)組中的某一項(xiàng):

    <div v-bind:class="[{ showClass: isShow }, classB]"></div>

    代碼解釋:

    在 HTML 中,div 綁定一個(gè)樣式數(shù)組,數(shù)組第一項(xiàng)是一個(gè)對象表達(dá)式 { showClass: isShow }。當(dāng) isShow 為 true 時(shí)樣式最終綁定為:<div v-bind:class="[showClass, classB]"></div>;當(dāng) isShow 為 false 時(shí)樣式最終綁定為:<div v-bind:class="[classB]"></div>;

    綁定內(nèi)聯(lián)樣式

    和 Class 的綁定一樣,Style 的綁定同樣可以通過數(shù)組和對象的兩種形式。

    1 對象語法

    v-bind:style 的對象語法十分直觀&mdash;&mdash;看著非常像 CSS,但其實(shí)是一個(gè) JavaScript 對象。CSS 屬性名可以用駝峰式 (camelCase) 或短橫線分隔 (kebab-case,記得用引號括起來) 來命名:

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>Document</title>
    </head>
    <body>
      <div id="app"> 
        <div v-bind:></div>
      </div>
    </body>
    <script src="https://unpkg.com/vue/dist/vue.js"></script>
    <script>var vm = new Vue({
    	el: '#app',
      data: {
        backgroundColor: 'red',
        width: 300
      }
    })</script>
    </html>

    渲染為:

    <div style =" background-color:red;width: 300px"></div>

    代碼解釋:

    在 HTML 代碼中,我們給 div 綁定 background-color 和 width 兩個(gè)內(nèi)聯(lián)樣式,它們的值在 data 中定義。

    在模板中寫較為復(fù)雜的表達(dá)式語法顯得比較繁瑣,通常直接綁定到一個(gè)樣式對象更好,這會(huì)讓模板顯得更加清晰:

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>Document</title>
    </head>
    <body>
      <div id="app"> 
        <div v-bind:></div>
      </div>
    </body>
    <script src="https://unpkg.com/vue/dist/vue.js"></script>
    <script>var vm = new Vue({
    	el: '#app',
      data: {
      	styleObject: {
          "background-color": 'red',
          width: '300px'
        }
      },
    })</script>
    </html>

    渲染為:

    <div style ="background-color:red;width: 300px"></div>

    代碼解釋:

    在 HTML 代碼中,我們給 div 綁定數(shù)據(jù) styleObject,它們的值在 data 中定義。

    2 數(shù)組語法

    v-bind:style 的數(shù)組語法可以將多個(gè)樣式對象應(yīng)用到同一個(gè)元素上:

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>Document</title>
    </head>
    <body>
      <div id="app"> 
        <div v-bind:></div>
      </div>
    </body>
    <script src="https://unpkg.com/vue/dist/vue.js"></script>
    <script>var vm = new Vue({
    	el: '#app',
      data: {
        stylesA: {
          "background-color": 'red',
          width: '300px'
        },
        stylesB: {
          color: '#fff',
          height: '300px'
        }
      }
    })</script>
    </html>

    渲染為:

    <div style ="background-color:red;width: 300px;color:#fff;height:300px"></div>

    讀到這里,這篇“Vue動(dòng)態(tài)樣式綁定的方法是什么”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。

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

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    vue
    AI