Vue的Class与Style绑定的方法
本文介绍了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-
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: jquery实现用户登陆界面(示例讲解)
下一篇: 详解Vue双向数据绑定原理解析