**1.5.1.** **效果** **(04\_class** **与** **style** **绑定****/test.html)** ![](https://box.kancloud.cn/9e28bfb18aa631b6d5a390f54674b2ac_1118x648.png) **1.5.2.** **理解** 1) 在应用界面中, 某个(些)元素的样式是变化的 2) class/style 绑定就是专门用来实现动态样式效果的技术 **1.5.3. class** **绑定** 1) :class='xxx' 2) 表达式是字符串: 'classA' 3) 表达式是对象: {classA:isA, classB: isB} 4) 表达式是数组: \['classA', 'classB'\] **1.5.4. style** **绑定** 1) :style="{ color: activeColor, fontSize: fontSize + 'px' }" 2) 其中 activeColor/fontSize 是 data 属性 **1.5.5.** **编码** ``` <div id="demo"> <h2>1. class绑定: :class='xxx'</h2> <p :class="myClass">xxx是字符串</p> <p :class="{classA: hasClassA, classB: hasClassB}">xxx是对象</p> <p :class="['classA', 'classB']">xxx是数组</p> <h2>2. style绑定</h2> <p :style="{color:activeColor, fontSize}">:style="{ color: activeColor, fontSize: fontSize + 'px' }"</p> <button @click="update">更新</button> </div> <script type="text/javascript" src="../js/vue.js"></script> <script type="text/javascript"> new Vue({ el: '#demo', data: { myClass: 'classA', hasClassA: true, hasClassB: false, activeColor: 'red', fontSize: '20px' }, methods: { update () { this.myClass = 'classB' this.hasClassA = !this.hasClassA this.hasClassB = !this.hasClassB this.activeColor = 'yellow' this.fontSize = '30px' } } }) </script> ```