數(shù)據綁定的一(yī)個常見(jiàn)需求場景是操縱元素的 CSS class 列表和(hé)內(nèi)聯樣式。因為(wèi) class 和(hé) style 都(dōu)是 attribute,我們可(kě)以和(hé)其他(tā) attribute 一(yī)樣使用 v-bind 将它們和(hé)動态的字符串綁定。但(dàn)是,在處理比較複雜(zá)的綁定時(shí),通(tōng)過拼接生成字符串是麻煩且易出錯的。因此,Vue 專門為(wèi) class 和(hé) style 的 v-bind 用法提供了(le)特殊的功能(néng)增強。除了(le)字符串外(wài),表達式的值也可(kě)以是對象或數(shù)組。
綁定 HTML class
綁定對象
我們可(kě)以給 :class (v-bind:class 的縮寫) 傳遞一(yī)個對象來動态切換 class:
template
<div :class="{ active: isActive }"></div>
上(shàng)面的語法表示 active 是否存在取決于數(shù)據屬性 isActive 的真假值。
你可(kě)以在對象中寫多個字段來操作(zuò)多個 class。此外(wài),:class 指令也可(kě)以和(hé)一(yī)般的 class attribute 共存。舉例來說,下(xià)面這(zhè)樣的狀态:
js
data() {
return {
isActive: true,
hasError: false
}
}
配合以下(xià)模闆:
template
<div
class="static"
:class="{ active: isActive, 'text-danger': hasError }"
></div>
渲染的結果會是:
template
<div class="static active"></div>
當 isActive 或者 hasError 改變時(shí),class 列表會随之更新。舉例來說,如(rú)果 hasError 變為(wèi) true,class 列表也會變成 "static active text-danger"。
綁定的對象并不一(yī)定需要(yào)寫成內(nèi)聯字面量的形式,也可(kě)以直接綁定一(yī)個對象:
js
data() {
return {
classObject: {
active: true,
'text-danger': false
}
}
}
template
<div :class="classObject"></div>
這(zhè)也會渲染出相同的結果。我們也可(kě)以綁定一(yī)個返回對象的計算屬性。這(zhè)是一(yī)個常見(jiàn)且很(hěn)有用的技巧:
js
data() {
return {
isActive: true,
error: null
}
},
computed: {
classObject() {
return {
active: this.isActive && !this.error,
'text-danger': this.error && this.error.type === 'fatal'
}
}
}
template
<div :class="classObject"></div>
綁定數(shù)組
我們可(kě)以給 :class 綁定一(yī)個數(shù)組來渲染多個 CSS class:
data() {
return {
activeClass: 'active',
errorClass: 'text-danger'
}
}
template
<div :class="[activeClass, errorClass]"></div>
渲染的結果是:
template
<div class="active text-danger"></div>
如(rú)果你也想在數(shù)組中有條件地(dì)渲染某個 class,你可(kě)以使用三元表達式:
template
<div :class="[isActive ? activeClass : '', errorClass]"></div>
errorClass 會一(yī)直存在,但(dàn) activeClass 隻會在 isActive 為(wèi)真時(shí)才存在。
然而,這(zhè)可(kě)能(néng)在有多個依賴條件的 class 時(shí)會有些冗長(cháng)。因此也可(kě)以在數(shù)組中嵌套對象:
template
<div :class="[{ active: isActive }, errorClass]"></div>
在組件上(shàng)使用
本節假設你已經有 Vue 組件的知識基礎。如(rú)果沒有,你也可(kě)以暫時(shí)跳(tiào)過,以後再閱讀。
對于隻有一(yī)個根元素的組件,當你使用了(le) class attribute 時(shí),這(zhè)些 class 會被添加到根元素上(shàng),并與該元素上(shàng)已有的 class 合并。
舉例來說,如(rú)果你聲明(míng)了(le)一(yī)個組件名叫 MyComponent,模闆如(rú)下(xià):
template
<!-- 子組件模闆 -->
<p class="foo bar">Hi!</p>
在使用時(shí)添加一(yī)些 class:
template
<!-- 在使用組件時(shí) -->
<MyComponent class="baz boo" />
渲染出的 HTML 為(wèi):
template
<p class="foo bar baz boo">Hi!</p>
Class 的綁定也是同樣的:
template
<MyComponent :class="{ active: isActive }" />
當 isActive 為(wèi)真時(shí),被渲染的 HTML 會是:
template
<p class="foo bar active">Hi!</p>
如(rú)果你的組件有多個根元素,你将需要(yào)指定哪個根元素來接收這(zhè)個 class。你可(kě)以通(tōng)過組件的 $attrs 屬性來實現指定:
template
<!-- MyComponent 模闆使用 $attrs 時(shí) -->
<p :class="$attrs.class">Hi!</p>
<span>This is a child component</span>
template
<MyComponent class="baz" />
這(zhè)将被渲染為(wèi):
html
<p class="baz">Hi!</p>
<span>This is a child component</span>
你可(kě)以在透傳 Attribute 一(yī)章(zhāng)中了(le)解更多組件的 attribute 繼承的細節。
綁定內(nèi)聯樣式
綁定對象
:style 支持綁定 JavaScript 對象值,對應的是 HTML 元素的 style 屬性:
js
data() {
return {
activeColor: 'red',
fontSize: 30
}
}
template
<div :style="{ color: activeColor, fontSize: fontSize + 'px' }"></div>
盡管推薦使用 camelCase,但(dàn) :style 也支持 kebab-cased 形式的 CSS 屬性 key (對應其 CSS 中的實際名稱),例如(rú):
template
<div :style="{ 'font-size': fontSize + 'px' }"></div>
直接綁定一(yī)個樣式對象通(tōng)常是一(yī)個好主意,這(zhè)樣可(kě)以使模闆更加簡潔:
js
data() {
return {
styleObject: {
color: 'red',
fontSize: '13px'
}
}
}
template
<div :style="styleObject"></div>
同樣的,如(rú)果樣式對象需要(yào)更複雜(zá)的邏輯,也可(kě)以使用返回樣式對象的計算屬性。
綁定數(shù)組
我們還可(kě)以給 :style 綁定一(yī)個包含多個樣式對象的數(shù)組。這(zhè)些對象會被合并後渲染到同一(yī)元素上(shàng):
template
<div :style="[baseStyles, overridingStyles]"></div>
自(zì)動前綴
當你在 :style 中使用了(le)需要(yào)浏覽器特殊前綴的 CSS 屬性時(shí),Vue 會自(zì)動為(wèi)他(tā)們加上(shàng)相應的前綴。Vue 是在運行(xíng)時(shí)檢查該屬性是否支持在當前浏覽器中使用。如(rú)果浏覽器不支持某個屬性,那(nà)麽将嘗試加上(shàng)各個浏覽器特殊前綴,以找到哪一(yī)個是被支持的。
樣式多值
你可(kě)以對一(yī)個樣式屬性提供多個 (不同前綴的) 值,舉例來說:
template
<div :style="{ display: ['-webkit-box', '-ms-flexbox', 'flex'] }"></div>
數(shù)組僅會渲染浏覽器支持的最後一(yī)個值。在這(zhè)個示例中,在支持不需要(yào)特别前綴的浏覽器中都(dōu)會渲染為(wèi) display: flex。
網站建設開(kāi)發|APP設計開(kāi)發|小程序建設開(kāi)發