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

详解vue.js之绑定class和style的示例代码

程序员文章站 2022-11-26 11:12:17
一.绑定class属性。 绑定数据用v-bind:命令,简写成: 语法:
&...

一.绑定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>
//js
var 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

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