Vue提供了一個(gè)很有用的指令:v-bind:class和v-bind:style,通過(guò)這兩個(gè)指令可以動(dòng)態(tài)的綁定類和樣式。但是有時(shí)候我們需要給某個(gè)元素添加一些特殊效果,并不能用類和樣式來(lái)控制,這時(shí)候就需要使用Vue的active指令了。
active指令可以讓元素在某些狀態(tài)下添加特殊效果,比如:鼠標(biāo)懸浮、點(diǎn)擊等。使用active指令非常簡(jiǎn)單,只需要在元素上添加v-active指令即可。下面是一個(gè)例子:
<div v-active="active"> ... </div>
在上面的例子中,我們給一個(gè)<div>元素添加了v-active指令,并且綁定了一個(gè)名為active的值。接下來(lái)我們可以為這個(gè)元素添加一些特殊效果了。比如,我們可以使用css來(lái)改變?cè)氐谋尘吧?/p>
div[active] { background-color: yellow; }
在上面的CSS中,我們使用了屬性選擇器來(lái)針對(duì)帶有active屬性的元素進(jìn)行樣式控制,并將背景色改為黃色。
除了css,我們也可以使用JavaScript來(lái)對(duì)元素添加特殊效果。在v-active指令中,還可以綁定一個(gè)函數(shù),用來(lái)動(dòng)態(tài)的改變?cè)氐臓顟B(tài),從而達(dá)到效果改變的目的。下面是一個(gè)例子:
<div v-active="activeFn"> ... </div> new Vue({ el: '#app', data: { activeFn: function() { console.log('元素被激活了!'); } } });
在上面的例子中,我們將一個(gè)函數(shù)綁定到了v-active指令上,當(dāng)元素被激活時(shí),函數(shù)會(huì)被觸發(fā),從而輸出一條信息到控制臺(tái)。
綜上所述,Vue的active指令可以讓我們更方便的為元素添加特殊效果,使得我們的頁(yè)面變得更加生動(dòng)和有趣。