Vue.js实例学习:Class 与 Style 绑定
2018-03-05 00:37
1401 查看
#绑定 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>
执行结果:
[b]4、也可以计算属性[/b]
我们也可以在这里绑定一个返回对象的计算属性。这是一个常用且强大的模式:
<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]"< 4000 /span>>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。
相关文章推荐
- Vue.js 学习5 Class与Style绑定
- 学习使用vue.js(五)绑定Style 与Class
- vue.js学习笔记之绑定style样式和class列表
- Vue.js-Class与Style绑定
- [js高手之路] vue系列教程 - 绑定class与行间样式style(6)
- Vue.js computed 例子 class与style绑定
- Vue学习—Class与Style绑定
- Vue.js Class与Style绑定
- Class 与 Style 绑定内联样式(vue.js)
- Vue.js笔记第二波,Class 与 Style 绑定,条件渲染,列表渲染
- Vue.js学习笔记:v-bind属性绑定(class,src)
- vue.js绑定class和style样式(6)
- vue学习笔记---class与style绑定以及条件渲染
- Vue.js之Class 与 Style 绑定
- Class 与 Style 绑定HTML Class(vue.js)
- 详解vue.js之绑定class和style的示例代码
- Vue.js笔记-计算属性 class与style绑定
- vue.js(6)-Class 与 Style 绑定
- vuejs教程4-Class 与 Style 绑定
- Vue.js 之 Class与Style绑定