时间:2021-05-26
数据绑定一个常见需求是操作元素的 class 列表和它的内联样式。因为它们都是 attribute,我们可以用 v-bind 处理它们:只需要计算出表达式最终的字符串。不过,字符串拼接麻烦又易错。因此,在 v-bind 用于 class 和 style 时,Vue.js 专门增强了它。表达式的结果类型除了字符串之外,还可以是对象或数组。
一.绑定Class属性。
绑定数据用v-bind:命令,简写成:
语法:<div v-bind:class="{ active: isActive }"></div>。class后面的双引号里接受一个对象字面量/对象引用/数组作为参数,
这里,{active: isActive}是对象参数,active是class名,isActive是一个布尔值。下面是一个例子:
绑定对象字面量
html:
<div id="classBind"><span :class="{warning:isWarning,safe:isSafe}" v-on:click="toggle">状态:{{alert}}{{isSafe}}</span></div>//jsvar app11=new Vue({el:'#classBind',data:{isWarning:true,alertList:['红色警报','警报解除'],alert:''},computed:{isSafe:function(){return !this.isWarning;}},methods:{toggle:function(){this.isWarning=!this.isWarning;this.alert= this.isWarning?this.alertList[0]:this.alertList[1];}}});css:
.warning{color:#f24;}.safe{color:#42b983;}当点击状态文字时,可以切换后面的文字和颜色
//状态:警报解除true
//状态:红色警报false
绑定对象引用
这里绑定的对象可以写到Vue实例的data里面,而在class="classObj ",双引号中的class是对Vue实例中classObj对象的引用。classObj可以放在data中或者computed中,如果在computed中,则classObj所对应的函数必须返回一个对象如下:
js:
var app11=new Vue({el:'#classBind',data:{isWarning:true,alertList:['红色警报','警报解除'],alert:''},computed: {isSafe: function () {return !this.isWarning;},classObj:function(){return {warning: this.isWarning,safe:this.isSafe}}},methods:{toggle:function(){this.isWarning=!this.isWarning;this.alert= this.isWarning?this.alertList[0]:this.alertList[1];}}});绑定数组
html:
<div v-bind:class="classArray" @click="removeClass()">去掉class</div>js
data: {classArray:["big",'red']}methods:{removeClass:function(){ this.classArray.pop();}}css:
.big{font-size:2rem;}.red{color:red; }效果,点击去掉class,会调用removeClass函数,去掉classArray数组的最后一项,第一次,去掉'red',字体颜色由红变黑,再点,去掉'big',字体变小。
二、绑定内联style
此时此刻,我一边看着本页旁边的那个Vue api文档学,一边到这里卖,装逼的感觉真爽o(^▽^)o
html
<div id="styleBind"><span :style="{color:theColor,fontSize:theSize+'px'}" @click="bigger">styleBind</span></div>css
这个不需要css。。。
js
var app12=new Vue({el:'#styleBind',data:{theColor:'red',theSize:14},methods:{bigger:function(){this.theSize+=2;}}});除了传入对象字面量以外,也可以传入对象引用和数组给V-bind:style
以上所述是小编给大家介绍的vue.js学习笔记之绑定style和class,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言在Vue.js版本:1.0.27,使用Vue.js中V-bind指令来绑定class和style时,Vue.js对其进行了增强。表达式结果出了字符串之外,还
关于vue.js中class与style绑定的练习代码,分享给大家,供大家参考:html:Vuejs中Class与Style绑定猴猴呀lowrie猴猴呀lowr
学习Vue的时候觉得样式绑定很简单,但是使用的时候总是容易搞晕自己。因为:class和:style里的数组语法和对象语法和data里绑定的值是不太一样的。这篇文
现在来系统地学习一下Vue(参考vue.js官方文档):Vue.js是一个构建数据驱动的web界面的库,其目标是实现响应的数据绑定和组合的试图组件。Vue.js
什么是Vue.js?Vue.js是用于构建交互式的Web界面的库。Vue.js提供了MVVM数据绑定和一个可组合的组件系统,具有简单、灵活的API。Vue.js