JavaScript

超轻量级php框架startmvc

Vue的Class与Style绑定的方法

更新时间:2020-06-02 19:30:01 作者:startmvc
本文介绍了Vue的Class与Style绑定,分享给大家,具体如下:绑定HTMLClass对象语法我们可以传

本文介绍了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-

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

vue.js 添加class vue绑定style vue.js class