绑定 HTML Class
对象语法
我们可以传给 v-bind:class 一个对象,以动态地切换 class。
<div v-bind:class="{ active: isActive }"></div>
上面的语法表示 class="active" 的更新将取决于数据属性 isActive 是否为 真值(true)。
我们也可以在对象中传入更多属性用来动态切换多个 class。此外,v-bind:class 指令可以与普通的 class 属性共存。如下示例:
<div id="app">
<div class="static"
v-bind:class="{ active: isActive, 'text-danger': hasError }">
{{ msg }}
</div>
</div>
<script>
var vm = new Vue({
el: "#app",
data: {
msg: "我是渲染 active 类",
isActive: true,
hasError: false
}
});
</script>
尝试一下
渲染输出如下图所示:
当 isActive 或者 hasError 变化时,class 列表将相应地更新。例如,如果 hasError 的值为 true , class 列表将变为 "static active text-danger"。
你也可以直接绑定数据里的一个对象:
<div id="app">
<div class="static"
v-bind:class="classObject">
{{ msg }}
</div>
</div>
<script>
var vm = new Vue({
el: "#app",
data: {
msg: "我是渲染 active 类",
classObject: {
active: true,
'text-danger': false
}
}
});
</script>
渲染的结果和上面示例一样。
我们也可以在这里绑定返回对象的
计算属性。这是一个常用且强大的模式:
<div id="app">
<div v-bind:class="classObject">
{{ msg }}
</div>
</div>
<script>
var vm = new Vue({
el: "#app",
data: {
msg: " 我是渲染 active 类",
isActive: true,
error: null
},
computed: {
classObject: function () {
return {
active: this.isActive && !this.error,
'text-danger': this.error && this.error.type === 'fatal'
}
}
}
});
</script>
尝试一下
数组语法
我们可以把一个数组传给 v-bind:class,以应用一个 class 列表:
<div id="app">
<div v-bind:class="[activeClass, errorClass]">
{{ msg }}
</div>
</div>
<script>
var vm = new Vue({
el: "#app",
data: {
msg: "我是渲染数组里的类名的",
activeClass: 'active',
errorClass: 'text-danger'
}
});
</script>
尝试一下
渲染输出如下图所示:
如果你也想根据条件切换列表中的 class,可以用三元表达式:
<div v-bind:class="[isActive ? activeClass : '', errorClass]">
此例始终添加 errorClass,但是只有在 isActive 是 true 时添加 activeClass。
不过,当有多个条件 class 时这样写有些繁琐。可以在数组语法中使用对象语法:
<div v-bind:class="[{ active: isActive }, errorClass]">
组件语法
当你在一个自定义组件上使用 class 属性时,那些添加的 class 值将会被添加至组件根元素上。根元素上已存在的 class 值将不会被覆盖。
例如,如果你声明一个这样的组件:
Vue.component('my-component', {
template: '<p class="foo bar">Hi</p>'
})
// 随后在组件上面添加一些 class:
<my-component class="baz boo"></my-component>
渲染出的HTML为:
<p class="foo bar baz boo">Hi</p>
这里我们同样可以用 class 绑定的形式:
<my-component v-bind:class="{ active: isActive }"></my-component>
当 isActive 是 true 时, 渲染的 HTML 将会是:
<p class="foo bar active">Hi</p>
想要了解更多 vue 组件相关的知识,请阅读我们 vuejs 组件的章节>>>