vue.js实现的绑定class操作示例

<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <meta content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <!-- Vue.js --> <script src="https://cdn.bootcss.com/vue/2.5.16/vue.min.js"></script> </head> <body> <div> <!--# 给v-bind设置一个对象,可以动态地切换class #--> <div :class="{'active':isActive}">app1</div> </div> <div> <!--# 给v-bind设置一个对象,可以动态地切换class #--> <!--# 对象中也可以传入多个属性,来动态切换class。另外,:class可以与普通class共存 #--> <div :class="{'active':isActive,'error':isError}">app2</div> </div> <div> <!--# 给v-bind设置一个对象,可以动态地切换class #--> <!--# 当:class的表达式过长或逻辑复杂时,还可以绑定一个计算属性,这是一种很友好和常见的用法,一般当条件多于两个时,都可以使用data或computer #--> <div :class="classes">app3</div> </div> </body> </html> <script> //例子一 var app1 = new Vue({ el:'#app1', data:{ //类名isActive,当其为true时,div会拥有类名active,为false时则没有 isActive:true } }); //例子二 var app2 = new Vue({ el:'#app2', data:{ //类名isActive,当其为true时,div会拥有类名active,为false时则没有 isActive:true, //类名isError,当其为true时,div会拥有类名error,为false时则没有 isError:true } }); //例子三 var app3 = new Vue({ el:'#app3', data:{ isActive:true, isError:false }, computed:{ classes:function () { return { active:this.isActive && !this.isError } //除了计算属性,你也可以直接绑定一个Object类型的数据,或者使用类似计算机属性的methods } } }) </script>

使用本站HTML/CSS/JS在线运行测试工具,可得到如下测试运行效果:

vue.js实现的绑定class操作示例

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/c50841e967b05ba8e602191a2b0ca715.html