zoukankan      html  css  js  c++  java
  • 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 的数组语法可以将多个样式对象应用到一个元素上

  • 相关阅读:
    SVN使用指引(Windows)
    Android开发14——监听内容提供者ContentProvider的数据变化
    Android开发13——内容提供者ContentProvider的基本使用
    Android开发12——Andorid中操作数据库的insert的两种方法以及nullColumnHack
    Android开发11——手机横屏和竖屏与android:configChanges
    Android开发10——Activity的跳转与传值
    Android开发9——Activity的启动模式
    Android开发8——利用pull解析器读写XML文件
    Android开发7——android.database.CursorIndexOutOfBoundsException:Index -1 requested
    Android开发6——布局中的wrap_content和fill_parent以及match_parent
  • 原文地址:https://www.cnblogs.com/LO-ME/p/7779184.html
Copyright © 2011-2022 走看看