绑定 HTML Class
对象语法
我们可以传给 v-bind:class 一个对象,以动态地切换 class。
上面的语法表示 class="active" 的更新将取决于数据属性 isActive 是否为 真值(true)。
我们也可以在对象中传入更多属性用来动态切换多个 class。此外,v-bind:class 指令可以与普通的 class 属性共存。如下示例:
渲染输出如下图所示:
当 isActive 或者 hasError 变化时,class 列表将相应地更新。例如,如果 hasError 的值为 true , class 列表将变为 "static active text-danger"。
你也可以直接绑定数据里的一个对象:
渲染的结果和上面示例一样。
我们也可以在这里绑定返回对象的
计算属性。这是一个常用且强大的模式:
数组语法
我们可以把一个数组传给 v-bind:class,以应用一个 class 列表:
渲染输出如下图所示:
如果你也想根据条件切换列表中的 class,可以用三元表达式:
此例始终添加 errorClass,但是只有在 isActive 是 true 时添加 activeClass。
不过,当有多个条件 class 时这样写有些繁琐。可以在数组语法中使用对象语法:
组件语法
当你在一个自定义组件上使用 class 属性时,那些添加的 class 值将会被添加至组件根元素上。根元素上已存在的 class 值将不会被覆盖。
例如,如果你声明一个这样的组件:
渲染出的HTML为:
这里我们同样可以用 class 绑定的形式:
当 isActive 是 true 时, 渲染的 HTML 将会是:
想要了解更多 vue 组件相关的知识,请阅读我们 vuejs 组件的章节>>>