說說在 Vue.js 中如何綁定樣式(class 或 style)

在數(shù)據(jù)綁定中,最常見就是動態(tài)綁定元素的 class 或內(nèi)聯(lián)樣式 style 咯如暖,它們也是 HTML 的屬性,所以可以使用 v-bind 指令 。

1 綁定 class

1.1 對象語法

使用 v-bind:class 屬性浩村,實(shí)現(xiàn)動態(tài)切換 class。

html:

<div id="app">
    <div :class="{'hidden':isHidden}">看得見我嘛</div>
</div>

js:

<script>
    var app = new Vue({
        el: '#app',
        data: {
            isHidden:true
        }
    });
</script>

輸出結(jié)果:

<div class="hidden">看得見我嘛</div>

注意: :classv-bind:class 的簡寫形式占哟。

示例中的類名 hidden 依賴于數(shù)據(jù) isHidden 心墅,當(dāng) isHidden 為 true 時酿矢, div 就會擁有類名 hidden,為 false 時就沒有該類名 怎燥。

我們也可以一次傳入多個屬性瘫筐,而且 :class 可以和常規(guī)的 class 同時使用。

html:

<div id="app">
    <div class="strong" :class="{'hidden':isHidden,'bigger':isBigger}">看得見我嘛</div>
</div>

js:

<script>
    var app = new Vue({
        el: '#app',
        data: {
            isHidden: false,
            isBigger: true
        }
    });
</script>

輸出結(jié)果:

<div class="strong bigger">看得見我嘛</div>

當(dāng) :class 中的某個屬性值為 true 時铐姚,就會加載對應(yīng)的類名策肝。

當(dāng) :class 的表達(dá)式過長或邏輯復(fù)雜時,我們可以通過計(jì)算屬性來綁定隐绵。

html:

<div id="app2">
    <div :class="customClasses"></div>
</div>

js:

var app2 = new Vue({
    el: '#app2',
    data: {
        isHidden: false,
        isBigger: true
    },
    computed: {
        customClasses: function () {
            return {
                display: !this.isHidden,
                'bigger-text': !this.isHidden && this.isBigger
            }
        }
    }
});

輸出結(jié)果:

<div class="display bigger-text"></div>

注意:如果樣式名稱帶有 -之众,那么必須加上單引號(示例中的 bigger-text)才能被正確識別。

1.2 數(shù)組語法

也可以使用數(shù)組語法依许,給 :class 綁定一個 class 數(shù)組棺禾。

html:

<div id="app">
    <div :class="[strongerClass,biggerClass]">號外!號外</div>
</div>

js:

<script>
    var app = new Vue({
        el: '#app',
        data: {
            strongerClass:'strong',
            biggerClass:'bigger'
        }
    });
</script>

輸出結(jié)果:

<div class="strong bigger">號外悍手!號外</div>

數(shù)組中的元素也可以使用三元表達(dá)式來計(jì)算

html:

<div id="app2">
    <div :class="[isStrong?strongerClass:'']">號外帘睦!號外</div>
</div>

js:

var app2 = new Vue({
    el: '#app2',
    data: {
        isStrong:true,
        strongerClass:'strong'
    }
});

輸出結(jié)果:

<div class="strong">號外!號外</div>

當(dāng)需要設(shè)置的 class 很多時坦康,我們可以在數(shù)組語法的基礎(chǔ)上使用對象語法竣付,從而簡化表達(dá)式,讓代碼變得更易維護(hù)滞欠。

html:

<div id="app3">
    <div :class="[{'strong':isStrong}]">號外古胆!號外</div>
</div>

js:

var app3 = new Vue({
    el: '#app3',
    data: {
        isStrong:true
    }
});

輸出結(jié)果:

<div class="strong">號外!號外</div>

也可以在 computed 或 methods 中返回需要設(shè)定的數(shù)組筛璧。

html:

<div id="app4">
    <div :class="btnClass">號外逸绎!號外</div>
</div>

js:

var app4 = new Vue({
    el: '#app4',
    data: {
        size: 'small',
        isGreen: true
    },
    computed: {
        btnClass: function () {
            return [
                'btn',
                {
                    ['btn-' + this.size]: this.size !== '',
                    ['btn-green']: this.isGreen
                }
            ];
        }
    }
});

輸出結(jié)果:

<div class="btn btn-small btn-green">號外!號外</div>

注意: 上述示例使用了 ECMAScript 6 語法夭谤,所以在 webStorm 中需要進(jìn)行設(shè)置(Setting → JavaScript → 選擇 ECMAScript 6 )否則會出現(xiàn)紅色波浪線哦:


在業(yè)務(wù)中會經(jīng)常會利用計(jì)算屬性為元素動態(tài)設(shè)置類名棺牧,尤其是在編寫可復(fù)用的組件時。所以在開發(fā)過程中朗儒,如果表達(dá)式較長或者邏輯較為復(fù)雜颊乘,建議優(yōu)先使用計(jì)算屬性哦O(∩_∩)O~

1.3 應(yīng)用于組件

如果直接在自定義組件中使用 class:class,那么樣式規(guī)則就會直接應(yīng)在這個組件的根元素上醉锄。

html:

<div id="app">
    <text-component :class="{'isStrong':isStrong}"></text-component>
</div>

js:

<script>
    Vue.component('text-component', {
        template: '<p class="content">不懂基因測序的學(xué)霸不是好的人工智能公司 CEO</p>'
    });
    var app = new Vue({
        el: '#app',
        data: {
            isStrong: true
        }
    });
</script>

css:

<style type="text/css">
    .isStrong{font-weight: bold}
</style>

渲染后代碼:

<p class="content isStrong">不懂基因測序的學(xué)霸不是好的人工智能公司 CEO</p>

效果


這種方式僅適用于把樣式應(yīng)用于自定義組件的根元素乏悄。如果需要給自定義組件中的子元素設(shè)置樣式,我們可以使用組件的 props 來實(shí)現(xiàn)恳不。

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

也可以使用 v-bind:style:style 直接給 HTML 元素綁定樣式檩小,它也有對應(yīng)的對象語法與數(shù)組語法。

html:

<div id="app">
    <div :style="border">馬斯克太空網(wǎng)計(jì)劃擴(kuò)大 FCC已允許1.2萬顆衛(wèi)星入軌</div>
</div>

js:

<script>
    var app = new Vue({
        el: '#app',
        data: {
            border:{
                border:'1px solid #00F',
                textShadow:'0 0 .3em gray'
            }
        }
    });
</script>

因?yàn)?JS 屬性不支持短橫分隔命名烟勋,所以我們這里使用 CSS 也支持的駝峰命名法规求。

渲染后代碼:

<div style="border: 1px solid rgb(0, 0, 255); text-shadow: gray 0px 0px 0.3em;">馬斯克太空網(wǎng)計(jì)劃擴(kuò)大 FCC已允許1.2萬顆衛(wèi)星入軌</div>

效果

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末筐付,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子阻肿,更是在濱河造成了極大的恐慌家妆,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,376評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件冕茅,死亡現(xiàn)場離奇詭異伤极,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)姨伤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評論 2 385
  • 文/潘曉璐 我一進(jìn)店門哨坪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人乍楚,你說我怎么就攤上這事当编。” “怎么了徒溪?”我有些...
    開封第一講書人閱讀 156,966評論 0 347
  • 文/不壞的土叔 我叫張陵忿偷,是天一觀的道長。 經(jīng)常有香客問我臊泌,道長鲤桥,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,432評論 1 283
  • 正文 為了忘掉前任渠概,我火速辦了婚禮茶凳,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘播揪。我一直安慰自己贮喧,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,519評論 6 385
  • 文/花漫 我一把揭開白布猪狈。 她就那樣靜靜地躺著箱沦,像睡著了一般。 火紅的嫁衣襯著肌膚如雪雇庙。 梳的紋絲不亂的頭發(fā)上谓形,一...
    開封第一講書人閱讀 49,792評論 1 290
  • 那天,我揣著相機(jī)與錄音状共,去河邊找鬼套耕。 笑死谁帕,一個胖子當(dāng)著我的面吹牛峡继,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播匈挖,決...
    沈念sama閱讀 38,933評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼碾牌,長吁一口氣:“原來是場噩夢啊……” “哼康愤!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起舶吗,我...
    開封第一講書人閱讀 37,701評論 0 266
  • 序言:老撾萬榮一對情侶失蹤征冷,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后誓琼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體检激,經(jīng)...
    沈念sama閱讀 44,143評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,488評論 2 327
  • 正文 我和宋清朗相戀三年腹侣,在試婚紗的時候發(fā)現(xiàn)自己被綠了叔收。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,626評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡傲隶,死狀恐怖饺律,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情跺株,我是刑警寧澤复濒,帶...
    沈念sama閱讀 34,292評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站乒省,受9級特大地震影響巧颈,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜袖扛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,896評論 3 313
  • 文/蒙蒙 一洛二、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧攻锰,春花似錦晾嘶、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至妒蛇,卻和暖如春机断,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背绣夺。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工吏奸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人陶耍。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓奋蔚,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子泊碑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,494評論 2 348

推薦閱讀更多精彩內(nèi)容

  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5坤按? 答:HTML5是最新的HTML標(biāo)準(zhǔn)。 注意:講述HT...
    kismetajun閱讀 27,449評論 1 45
  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容馒过,還有我對于 Vue 1.0 印象不深的內(nèi)容臭脓。關(guān)于...
    云之外閱讀 5,046評論 0 29
  • 概要 64學(xué)時 3.5學(xué)分 章節(jié)安排 電子商務(wù)網(wǎng)站概況 HTML5+CSS3 JavaScript Node 電子...
    阿啊阿吖丁閱讀 9,125評論 0 3
  • HTML 5 HTML5概述 因特網(wǎng)上的信息是以網(wǎng)頁的形式展示給用戶的,因此網(wǎng)頁是網(wǎng)絡(luò)信息傳遞的載體腹忽。網(wǎng)頁文件是用...
    阿啊阿吖丁閱讀 3,866評論 0 0
  • 二姐頂著酷熱到寧夏旅游来累,白天將近40°的氣溫曬得眼前一片明晃晃。烈日地下挑戰(zhàn)各種游戲窘奏,她說一不小心摸一下扶手都有被...
    mimi播報閱讀 454評論 2 5