时间:2021-05-26
本文介绍了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-以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
关于vue.js中class与style绑定的练习代码,分享给大家,供大家参考:html:Vuejs中Class与Style绑定猴猴呀lowrie猴猴呀lowr
vue计算属性在模板中放入大量的逻辑会让模板过重且难以维护计算属性下所有函数可以放到computed中class与style绑定原始写法v-bind:class
前言在Vue.js版本:1.0.27,使用Vue.js中V-bind指令来绑定class和style时,Vue.js对其进行了增强。表达式结果出了字符串之外,还
引子v-bind主要用于属性绑定,Vue官方提供了一个简写方式:bind,例如:一、概述v-bind主要用于属性绑定,比方你的class属性,style属性,v
学习Vue的时候觉得样式绑定很简单,但是使用的时候总是容易搞晕自己。因为:class和:style里的数组语法和对象语法和data里绑定的值是不太一样的。这篇文