绑定数据用v-bind:命令,简写成:css
语法:<div v-bind:class="{ active: isActive }"></div>。class后面的双引号里接受一个对象字面量/对象引用/数组做为参数,html
这里,{active: isActive}是对象参数,active是class名,isActive是一个布尔值。下面是一个例子:api
html:数组
<div id="classBind"> <span :class="{warning:isWarning,safe:isSafe}" v-on:click="toggle"> 状态:{{alert}}{{isSafe}} </span> </div>
//js
var app11=new Vue({
el:'#classBind',
data:{
isWarning:true,
alertList:['红色警报','警报解除'],
alert:''
},
computed:{
isSafe:function(){
return !this.isWarning;
}
},
methods:{
toggle:function(){
this.isWarning=!this.isWarning;
this.alert= this.isWarning?this.alertList[0]:this.alertList[1];
}
}
});
css:app
.warning{ color:#f24; } .safe{ color:#42b983; }
当点击状态文字时,能够切换后面的文字和颜色函数
//状态:警报解除true字体
//状态:红色警报falsethis
这里绑定的对象能够写到Vue实例的data里面,而在class="classObj ",双引号中的class是对Vue实例中classObj对象的引用。classObj能够放在data中或者computed中,若是在computed中,则classObj所对应的函数必须返回一个对象以下:spa
js:code
var app11=new Vue({ el:'#classBind', data:{ isWarning:true, alertList:['红色警报','警报解除'], alert:'' }, computed: { isSafe: function () { return !this.isWarning; }, classObj:function(){ return { warning: this.isWarning, safe:this.isSafe } } }, methods:{ toggle:function(){ this.isWarning=!this.isWarning; this.alert= this.isWarning?this.alertList[0]:this.alertList[1]; } } });
html:
<div v-bind:class="classArray" @click="removeClass()">去掉class</div>
js
data: { classArray:["big",'red'] }
methods:{
removeClass:function(){
this.classArray.pop();
}
}
css:
.big{ font-size:2rem; } .red{ color:red; }
效果,点击去掉class,会调用removeClass函数,去掉classArray数组的最后一项,第一次,去掉'red',字体颜色由红变黑,再点,去掉'big',字体变小。
此时此刻,我一边看着本页旁边的那个Vue api文档学,一边到这里卖,装逼的感受真爽o(^▽^)o
html
<div id="styleBind"> <span :style="{color:theColor,fontSize:theSize+'px'}" @click="bigger">styleBind</span> </div>
css
这个不须要css。。。
js
var app12=new Vue({ el:'#styleBind', data:{ theColor:'red', theSize:14 }, methods:{ bigger:function(){ this.theSize+=2; } } });
除了传入对象字面量之外,也能够传入对象引用和数组给V-bind:style