最近在作些小程序转Vue相关的工做,里面有很多涉及到style和class绑定的,为了避免至于用乱,我把小程序和Vue绑定方式都罗列了一下。
小程序里面的class与style绑定,遵循HTML特性绑定,有关于HTML绑定,我在上一篇文章中有总结过,可点击查看。在进行class与style绑定时,能够直接绑定,也能够带上逻辑与,或者三元运算进行条件控制小程序
JS
data: {
dClass: 'my-class',
dClass1: 'my-class1',
dClass2: 'my-class2',
dClass3: 'my-class3',
dStyle: 'color:red;'
}
WXML
<view class="{{dClass}}"></view>
<view class="{{truthy ? dClass1 : dClass2}}"></view>
<view class="{{truthy && dClass3}}"></view>
<view style="{{dStyle}}"></view>
复制代码
在Vue里面,class与style绑定一样遵循着HTML绑定,咱们只须要经过表达式计算出字符串便可,表达式结果的类型除了字符串以外,还能够是对象和数组。数组
JS
data() {
return {
dClass: 'my-class'
}
}
HTML
<div :class="dClass"></div>
复制代码
JS
data() {
return {
showC1: true,
showC2: true,
showC3: true
}
}
HTML
<div :class="{class1: showC1}"></div>
<div :class="{'class-2': showC2, 'class-3': showC3}"></div>
复制代码
:class指令能够与普通的class属性共存,若是你打算不管如何都要添加一个class,放置到普通的class属性中便可,好比:bash
JS
data() {
return {
showC1: true
}
}
HTML
<div class="static" :class="{class1: showC1}"></div>
复制代码
绑定的数据能够直接定义在data里面,好比:post
JS
data() {
return {
classObj: {
'class-1': true,
'class-2': false,
'class-3': true
}
}
}
HTML
<div :class="classObj"></div>
复制代码
绑定一个返回对象的计算属性,好比:ui
JS
data() {
return {
classObj: {
'class-1': true,
'class-2': false
}
}
}
HTML
<div :class="classObj"></div>
复制代码
JS
data() {
return {
activeClass: 'active',
errorClass: 'error'
}
}
HTML
<div :class="[activeClass, errorClass]"></div>
复制代码
使用三元表达式切换列表中的class,好比:spa
JS
data() {
return {
showC1: true
}
}
HTML
<div :class="[showC1 ? 'class-1' : '']"></div>
复制代码
老是添加一个class:code
JS
data() {
return {
showC1: true
}
}
HTML
<div :class="[showC1 ? 'class-1' : '', 'class-2']"></div>
复制代码
在数组中使用对象语法:cdn
JS
data() {
return {
showC1: true
}
}
HTML
<div :class="[{'class-1': showC1}, 'class-2']"></div>
复制代码
JS
data() {
return {
activeColor: 'red',
fontSize: 30
}
}
HTML
<div :style="{color: activeColor, fontSize: fontSize + 'px'}"></div>
复制代码
直接绑定一个样式对象,CSS 属性名能够用驼峰式 (camelCase) 或短横线分隔 (kebab-case,记得用单引号括起来) 来命名:对象
JS
data() {
return {
styleObj: {
'background-color': 'red',
fontSize: '30px'
}
}
}
HTML
<div :style="styleObj"></div>
复制代码
JS
data() {
return {
selfObj: {
width: '100px',
height: '50px'
},
childObj: {
backgroundColor: 'red',
'font-size': '30px'
}
}
}
HTML
<div :style="[selfObj, childObj]"></div>
复制代码