欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue的Class与Style绑定的方法

程序员文章站 2022-09-08 10:58:35
本文介绍了vue的class与style绑定,分享给大家,具体如下: 绑定 html class 对象语法 我们可以传给 v-bind:class 一个对...

本文介绍了vue的class与style绑定,分享给大家,具体如下:

绑定 html class

对象语法

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

<style>
  .exp{
    border: 1px solid #ccc;
  }
  .forexp{
    background: blue;
  }
</style>
<div class="exp" v-bind:class="{newexp:isnewexp}"></div>
<script>
  var exp=new vue({
    el:".exp".
    data:{
      isforexp:false
    }
  })
</script>

如上,我们先给 .exp 一个边框,我们利用 v-bind 方法传入一个新的 class 属性 .newexp,设置一个蓝色的背景颜色。当我们在控制台修改 .newexp 的属性为 true 时,会给 div 添加一个蓝色的背景颜色。

我们也可以传入更多的属性来切换多个 class 。

<div class="exp" v-bind:class="{newexp:isexp,npc:isnpc}"></div>
<script>
  data:{
    isexp:false,
    isnpc:true
  }
</script>

在模板里的渲染结果为:

<div class="exp isnpc"></div>

我们也可以使用对象的方法来切换属性

<div class="exp" v-bind:class="obj"></div>
<script>
  data:{
    obj:{
      newexp:false,
      npc:true
    }
  }
</script>

渲染结果和上面的一样

数组语法

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

<div class="exp" v-bind:class="[newexp,oldexp]"></div>
<script>
  data:{
    newexp:"new",
    oldexp:"old"
  }
</script>

渲染为:

<div class="exp new old"></div>

要切换class,使用三元运算符:

<div class="exp" v-bind:class="[act? newexp:oldexp]"></div>
<script>
  data{
    newexp:"new",
    oldexp:"old",
    act:true
  }
<script>

act 为 true 时,添加 new ,为 false 时添加 old。

用在组件上

声明一个组件:

vue.component("my", {
  template: '<p class="foo bar">hi</p>'
})

然后在使用它的时候添加一些 class:

<my class="tip"></my>

最终渲染为

<p class="foo bar tip">hi</p>

同样的适用于绑定 html class:

<my v-bind:class="{ active: isactive }"></my>

当active为true时,html 将被渲染成为:

<p class="foo bar active">hi</p>

绑定内联样式

对象语法

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

<div v-bind:style="{ color: activecolor, fontsize: fontsize + 'px' }"></div>
<script>
  data:{
    activecolor:"blue",
    fontsize:20
  }
</script>

使用对象语法的话,会看起来更加清晰

<div v-bind:style="obj"></div>
<script>
  data:{
    obj:{
      color:"#fff",
      fontsize:"20px"
    }
  }
</script>

数组语法

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

<div v-bind:style="[style1,style2]"></div>
<script>
  data:{
    style1:{
      color:"#666"
    },
    style2:{
      background:"#b1b1b1"
    }
  }
</script>

自动添加前缀

当 v-bind:style 使用需要特定前缀的 css 属性时,如 transform,vue.js 会自动侦测并添加相应的前缀。

chrome 和 safari : -webkit-
ie :        -ms-
firfox :      -moz-
opera :      -o-

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。