操作元素的 class 列表和内联样式是数据绑定的一个常见需求。因为它们都是 attribute,所以我们可以用 v-bind 处理它们:只需要通过表达式计算出字符串结果即可。不过,字符串拼接麻烦且易错。因此,在将 v-bind 用于 class 和 style 时,Vue.js 做了专门的增强。表达式结果的类型除了字符串之外,还可以是对象或数组。


目录

  • 一、绑定Class
  • 1.对象语法
  • 2.三目运算符语法
  • 3.数组语法
  • 二、绑定Style
  • 1.对象语法
  • 2.数组语法
  • 3.自动添加前缀


一、绑定Class

1.对象语法

我们可以传给 v-bind:class 一个对象,以动态地切换 class:

<div class="box" :class="{active:isActive}"></div>
var app = new Vue({
    el: "#app",
    data: {
        isActive: false,
    },
});

是否为元素添加active类名,取决于isActive的值,在本例中isActive的值为false,所以并为对该元素添加active类名,所以最终渲染结果如下:

<div class="box"></div>

也可以对象中传入更多字段来动态切换多个 class,例如:

<div class="box" :class="{active1:isActive1,'active2':isActive2}"></div>
var app = new Vue({
    el: "#app",
    data: {
        isActive1: true,
        isActive2: false,
    },
});

在本例中isActive1的值为true,所以成功为该元素添加active1类名,isActive2的值为false,所以并未对该元素添加active2类名,所以最终渲染结果如下:

<div class="box active1"></div>

2.三目运算符语法

如果想根据条件切换列表中的 class,可以用三元表达式:

<div class="box" :class="isActive3?'active1':'active2'"></div>
var app = new Vue({
    el: "#app",
    data: {
        isActive3: false,
    },
});

如果isActive3的值为true,则为元素添加类名active1,如果为false,则为元素添加类名active2,在本例中isActive3的值为false,所以应为该元素添加active2类名,所以最终渲染结果如下:

<div class="box active2"></div>

3.数组语法

我们可以把一个数组传给 v-bind:class,以应用一个 class 列表:

<div class="box" :class=[activeClass1,activeClass2]></div>
var app = new Vue({
    el: "#app",
    data: {
        activeClass1:'active1',
        activeClass2:'active2',
    },
});

渲染为:

<div class="box active1 active2"></div>

如果你也想根据条件切换列表中的 class,可以与三元表达式配合使用:

<div class="box" :class="[activeClass3,isActive4?'active4':'']"></div>
var app = new Vue({
    el: "#app",
    data: {
        isActive4: false,
        activeClass3:"active3"
    },
});

渲染为:

<div class="box active3"></div>

不过,当有多个条件 class 时这样写有些繁琐。所以在数组语法中也可以使用对象语法:

<div class="box" :class="[activeClass3,{active4:isActive4}]"></div>

二、绑定Style

1.对象语法

<div class="con" :style="{color:myColor,fontSize:myFontSize + 'px'}"></div>
var app = new Vue({
    el: "#app",
    data: {
        myColor: "pink",
        myFontSize: 20,
    },
});

注意点:CSS property 名需要使用驼峰式来命名。如上例中的font-size属性需要改写为fontSize;如果属性值为数值带有单位的,需要将数值和单位分开写,如上例的20px,需将数字20赋值到myFontSize变量中,而在使用+符号添加上px单位。
为了让模板更加清晰,通常我们会直接绑定到一个样式对象上,如下所示:

<div v-bind:style="styleObject"></div>
var app = new Vue({
    el: "#app",
    data: {
        styleObject: {
          color: "pink",
          fontSize: "20px",
        },
    },
});

2.数组语法

v-bind:style 的数组语法可以将多个样式对象应用到同一个元素上:

<div v-bind:style="[styleObject, overridingStyles]"></div>
var app = new Vue({
    el: "#app",
    data: {
        styleObject: {
          color: "pink",
          fontSize: "20px",
        },
        baseStyles: {
            backgroundColor:'skyblue'
        },
    },
});

3.自动添加前缀

当 v-bind:style 使用需要添加浏览器引擎前缀的 CSS property 时,如 transform,Vue.js 会自动侦测并添加相应的前缀。