Vue.js实例学习:Class 与 Style 绑定

15 篇文章 1 订阅

绑定 HTML Class


一、对象语法

我们可以传给 v-bind:class 一个对象,以动态地切换 class

<style type="text/css">
.static{
  background: red;
}
.active{
  background: blue;
  width: 100px;
}
.test{
  background: yellow;
  height: 100px;
}
</style>

<!-- active、test为类名;
其isactive、is的值为true/false
决定着active、test这两个类是否生效。-->
<div class="static" v-bind:class="{active:isactive,test:is}">{{ fullName }}</div>

<script type="text/javascript">
  var vm = new Vue({
      el:".static",
      data:{
        fullName:"ada",
        isactive:false,//true or false
        is:false,      //true or false
        active:"aa"    //跟上面active没关系,两者互不影响
      },
  });
</script> 

1、上面代码 执行结果:
这里写图片描述
2、如果我们将上面 isactive的值改为true ; is的值仍为false;

html部分相当于:(部分不必要部分已简化)

<div class="static active">{{ fullName }}</div>

我们发现此时.active 生效;宽度变为100px;背景变为蓝色。
执行结果:
这里写图片描述
3、我们再将上面的 isactive、is值均改为true ;
此时高度变为100px;背景变为黄色。

html部分相当于:(部分不必要部分已简化)

<div class="static active test">{{ fullName }}</div>

执行结果:
这里写图片描述
4、也可以计算属性
我们也可以在这里绑定一个返回对象的计算属性。这是一个常用且强大的模式:

<div v-bind:class="classObject"></div>
data: {
  isActive: true,
  error: null
},
computed: {
  classObject: function () {
    return {
      active: this.isActive && !this.error,
      test: this.error && this.error.type === 'fatal'
    }
  }
}

二、数组语法

<style type="text/css">
.static{
  background: red;
}
.active{
  background: blue;
  width: 100px;
}
.test{
  background: yellow;
  height: 100px;
}
</style>

<div class="static" v-bind:class="[activeClass, errorClass]">dada</div>

<script type="text/javascript">
var vm = new Vue({
  el:".static",
  data:{
    activeClass:"active",
    errorClass:"test"
  },
});
</script> 

1、因为activeClass、errorClass不为空,所以.active、.test均生效。

输出结果:
这里写图片描述html相当于渲染为:

<div class="static active test"></div>

可见class的顺序(从左至右):
原html的class -> v-bind:绑定的class

2、在数组语法中也可以使用对象语法

<div v-bind:class="[{ active: isActive }, errorClass]"></div>

三、用在组件上

这里我们使用的是组件的全局注册。

<div id="example">
  <my-component class="class3" v-bind:class="{ class4: isActive }"></my-component>
</div>
  
<script type="text/javascript">
// 注册 (注册必须在 创建根实例之前,否则失效)
Vue.component('my-component', {
  template: '<div class="class1 class2">A custom component!</div>'
})

// 创建根实例
new Vue({
   el: '#example',
   data:{
     isActive:true,
   }
})
</script> 

执行后
HTML 被渲染为:

<div class="class1 class2 class3 class4">A custom component!</div>

可见使用组件时class的顺序(从左至右):
注册组件时的class -> 使用组件时添加的class -> 使用组件时v-bind:绑定的class



绑定内联样式


一、对象语法

v-bind:style 的对象语法十分直观——看着非常像 CSS,但其实是一个 JavaScript 对象。

<div id="app">
  <div v-bind:style = "{color:mycolor,fontSize:myfontsize + 'px'}">666</div>
</div>

<!--这种方式效果 等效于上面;
说明vue遵循了css的规则,对绑定父元素的子元素也生效,-->
<!-- <div id="app" v-bind:style = "{color:mycolor,fontSize:myfontsize + 'px'}">666</div> -->

<script type="text/javascript">
var vm = new Vue({
  el:"#app",
  data:{
    mycolor:'red',
    myfontsize:'40',
  },
});
</script> 

执行结果:
这里写图片描述

直接绑定到一个样式对象通常更好,这会让模板更清晰:

优化上面代码:

<div id="app" v-bind:style = "styleObject">666</div>

<script type="text/javascript">
var vm = new Vue({
  el:"#app",
  data:{
    styleObject:{
      color:'red',
      fontSize:'40px',
    }
  }
});
</script> 

执行结果同上。

二、数组语法

用法:数组里套对象。
v-bind:style 的数组可以将多个样式对象应用到同一个元素上:

<div id="app" v-bind:style = "[styleObj1,styleObj2]">666</div>

<script type="text/javascript">
var vm = new Vue({
  el:"#app",
  data:{
    styleObj1:{
      color:'red',
      fontSize:'40px',
    },
    styleObj2:{
      letterSpacing:"100px",
    }
  }
});
</script> 

执行结果:
这里写图片描述

三、自动添加前缀

当 v-bind:style 使用需要添加浏览器引擎前缀的 CSS 属性时,如 transform,
Vue.js 会自动侦测并添加相应的前缀。

四、多重值

从 2.3.0 起你可以为 style 绑定中的属性提供一个包含多个值的数组,常用于提供多个带前缀的值,例如:

display: -webkit-box;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;

<div:style="{ display: ['-webkit-box', '-ms-flexbox', 'flex'] }"></div>

这样写只会渲染数组中最后一个被浏览器支持的值。在本例中,如果浏览器支持不带浏览器前缀的 flexbox,那么就只会渲染 display: flex。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值