v-bind指令动态绑定class和内联样式style

动态绑定class—概述

数据绑定(v-bind指令)一个常见需求是操作元素的 class 列表。因为class是元素的一个属性,我们可以用 v-bind 处理它们

我们只需要计算出表达式最终的字符串。不过,字符串拼接麻烦又易错。

因此,在v-bind 用于 class 时,Vue.js 专门增强了它。表达式的结果类型除了字符串之外,还可以是对象或数组。

 

 

动态绑定class—对象语法

我们可以传给 v-bind:class 一个对象,以动态地切换 class 。v-bind:class 指令可以与普通的 class 属性共存

下面的语法表示 class ,active是否添加将取决于数据属性 isActive 是否为真值 。也可以在对象中传入更多属性用来动态切换多个 class 。

下面代码中当 isActive 或者 isFontSize变化时,class 列表将相应地更新。例如,如果 isFontSize的值为 true , class列表将变为 "bg active font-size"

需要注意的是当class的名字是xx-xxx这种带横线的类名时,需要加上单引号,不然会报错

<template>
  <!--template模板只能有一个根元素-->
  <div id="app">
    <p class="bg" v-bind:class="{active:isActive,'font-size':isFontSize}">
      例如,如果 isFontSize的值为 true , class列表将变为 "bg active font-size"
    </p>
  </div>
</template>

<script>
export default {
  name: 'app',
  data () {
    return {
      isActive: true,
      isFontSize: true
    }
  }
}
</script>
<style>
  .active{
    color: red;
  }
  .bg{
    background-color: blue;
  }
  .font-size{
    font-size: 18px;
  }
</style>

也可以直接绑定数据里的一个对象,这种写法是将样式的class名字放在这个对象中,然后是用v-bind绑定的时候绑定这个对象名字

<template>
  <!--template模板只能有一个根元素-->
  <div id="app">
    <p class="bg" v-bind:class="classObject">
      例如,如果 isFontSize的值为 true , class列表将变为 "bg active font-size"
    </p>
  </div>
</template>

<script>
export default {
  name: 'app',
  data () {
    return {
      classObject: {
        active: true,
        'font-size': true
      }
    }
  }
}
</script>
<style>
  .active{
    color: red;
  }
  .bg{
    background-color: blue;
  }
  .font-size{
    font-size: 18px;
  }
</style>

 也可以在这里绑定返回对象的计算属性。这是一个常用且强大的模式

<template>
  <!--template模板只能有一个根元素-->
  <div id="app">
    <p class="bg" v-bind:class="classObject">
      例如,如果 isFontSize的值为 true , class列表将变为 "bg active font-size"
    </p>
  </div>
</template>

<script>
export default {
  name: 'app',
  data () {
    return {
      active: true,
      isActive: false
    }
  },
  computed: {
    classObject: function () {
      return {
        active: this.active && !this.isActive,
        'font-size': this.active || this.isActive
      }
    }
  }
}
</script>
<style>
  .active{
    color: red;
  }
  .bg{
    background-color: blue;
  }
  .font-size{
    font-size: 18px;
  }
</style>

 

 

 

 

 

动态绑定class—数组语法

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

<template>
  <!--template模板只能有一个根元素-->
  <div id="app">
    <p class="bg" v-bind:class="[isActive,isFontSize]">
      例如,如果 isFontSize的值为 true , class列表将变为 "bg active font-size"
    </p>
  </div>
</template>

<script>
export default {
  name: 'app',
  data () {
    return {
      isActive: 'active',
      isFontSize: 'font-size'
    }
  }
}
</script>
<style>
  .active{
    color: red;
  }
  .bg{
    background-color: blue;
  }
  .font-size{
    font-size: 18px;
  }
</style>

根据条件切换列表中的 class ,可以用三元表达式。下面此例始终添加 font-size这个class ,但是只有在 isActive 是 true 时才添加 active这个class

<template>
  <!--template模板只能有一个根元素-->
  <div id="app">
    <p class="bg" v-bind:class="[isActive ? activeClass : '',isFontSize]">
      例如,如果 isFontSize的值为 true , class列表将变为 "bg active font-size"
    </p>
  </div>
</template>

<script>
export default {
  name: 'app',
  data () {
    return {
      isActive: true,
      activeClass: 'active',
      isFontSize: 'font-size'
    }
  }
}
</script>
<style>
  .active{
    color: red;
  }
  .bg{
    background-color: blue;
  }
  .font-size{
    font-size: 18px;
  }
</style>

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

<template>
  <!--template模板只能有一个根元素-->
  <div id="app">
    <p class="bg" v-bind:class="[{active:isActive},isFontSize]">
      例如,如果 isFontSize的值为 true , class列表将变为 "bg active font-size"
    </p>
  </div>
</template>

<script>
export default {
  name: 'app',
  data () {
    return {
      isActive: true,
      isFontSize: 'font-size'
    }
  }
}
</script>
<style>
  .active{
    color: red;
  }
  .bg{
    background-color: blue;
  }
  .font-size{
    font-size: 18px;
  }
</style>

 

 

 

 

动态绑定内联样式style—概述

数据绑定(v-bind指令)另一个常见需求是操作元素的内联样式。因为它是属性,我们可以用 v-bind 处理它们
我们只需要计算出表达式最终的字符串。不过,字符串拼接麻烦又易错。因此,在v-bind 用于 style 时,Vue.js 专门增强了它。表达式的结果类型除了字符串之外,还可以是对象或数组。

 

 

动态绑定内联样式style—对象语法

v-bind:style 的对象语法十分直观——看着非常像 CSS ,其实它是一个 JavaScript 对象。 CSS 属性名可以用驼峰式(camelCase)或短横分隔命名(kebab-case)

<template>
  <div id="app">
    <p v-bind:style="{color:colorStyle,fontSize:fontSizeStyle+'px'}">
      例如,如果isFontSize的值为true,class列表将变为 "bg active font-size"
    </p>
  </div>
</template>

<script>
export default {
  name: 'app',
  data () {
    return {
      colorStyle: 'red',
      fontSizeStyle: 20
    }
  }
}
</script>
<style></style>

直接绑定到一个样式对象通常更好,让模板更清晰

同样的,对象语法常常结合返回对象的计算属性使用

 

 

动态绑定内联样式style—数组语法

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

posted @ 2017-11-03 17:16  胡椒粉hjf  阅读(1518)  评论(0编辑  收藏  举报