源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Vue的Class与Style绑定的方法

  • 时间:2020-11-26 17:59 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Vue的Class与Style绑定的方法
本文介绍了Vue的Class与Style绑定,分享给大家,具体如下: [b]绑定 HTML Class[/b] [b]对象语法[/b] 我们可以传给 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>
渲染结果和上面的一样 [b]数组语法[/b] 我们可以把一个数组传给 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。 [b]用在组件上[/b] 声明一个组件:
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>
[b]绑定内联样式[/b] [b]对象语法[/b] 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>
[b]数组语法[/b] v-bind:style 的数组语法可以将多个样式对象应用到一个元素上:
<div v-bind:style="[style1,style2]"></div>
<script>
  data:{
    style1:{
      color:"#666"
    },
    style2:{
      background:"#b1b1b1"
    }
  }
</script>
[b]自动添加前缀[/b] 当 v-bind:style 使用需要特定前缀的 CSS 属性时,如 transform,Vue.js 会自动侦测并添加相应的前缀。
Chrome 和 Safari : -webkit-
IE :        -ms-
Firfox :      -moz-
Opera :      -o-
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部