作者:PureView 字体:[增加 减小] 类型:转载 时间:2017-09-01 我要评论
本文介绍了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-