适用范围:
操作元素的 class 列表和内联样式是数据绑定的一个常见需求。因为它们都是 attribute,所以我们可以用 v-bind 处理它们:只需要通过表达式计算出字符串结果即可。不过,字符串拼接麻烦且易错。因此,在将 v-bind 用于 class 和 style 时,Vue.js 做了专门的增强。
梗概:
当绑定class或style属性时
- 表达式结果的类型除了字符串之外,还可以是对象或数组。
- 在组件外面可以为组件里面的标签添加类
- 绑定style相当于添加内联style
对象语法:
1. 绑定class
你可以在对象中传入更多字段来动态切换多个 class。此外,:class 指令也可以与普通的 class attribute 共存。
当有如下模板:
<div
class="static"
:class="{ active: isActive, 'text-danger': hasError }"
></div>和如下 data:
data() {
return {
isActive: true,
hasError: false
}
}渲染的结果为:
<div class="static active"></div>绑定的数据对象不必内联定义在模板里:
<div :class="classObject"></div>data() {
return {
classObject: {
active: true,
'text-danger': false
}
}
}2. 绑定style
<div :style="styleObject"></div>data() {
return {
styleObject: {
color: 'red',
fontSize: '13px'
}
}
}1. 数组语法:
1. 绑定class:
传入一个数组, 数组的每一个元素都将作为一个类
2. 绑定style:
传入一个数组, 元素为对象, 多个对象内的样式将会叠加
1. 为组件内标签添加类:
1. 实例:
const app = Vue.createApp({})
app.component('my-component', {
template: `<p class="foo bar">Hi!</p>`
})<div id="app">
<my-component class="baz boo"></my-component>
</div>最终渲染为
<p class="foo bar baz boo">Hi</p>