这篇文章主要为大家详细介绍了Vue 样式绑定的实现方法,具有一定的参考价值,可以用来参考一下。
感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!
学习 Vue 的时候觉得样式绑定很简单,但是使用的时候总是容易搞晕自己。因为 :class 和 :style 里的数组语法和对象语法和 data 里绑定的值是不太一样的。这篇文章就简单对 Vue 绑定做个总结。
操作元素的class列表和内联样式是数据绑定的一个常见需求,因为它们都是属性,所以可用v-bind处理,通过表达式计算出字符串结果即可。不过字符串拼接麻烦且易错。因此,在将v-bind用于class和style时,Vue做了专门增强,表达式结果类型除了字符串之外,还可是对象或数组。
data 里的属性是负责 toggle 是否要这个 class,也就是一般定义 Boolean 类型的值。
代码如下:
<div :class="{ active: isActive, 'text-danger': hasError }"></div>
这里用 isActive 和 hasError 定义是否需要 active 和 text-danger 类。
代码如下:
data: {
isActive: true,
hasError: false
}
渲染为
代码如下:
<div class="active"></div>
data 里负责定义 CSS 类名。
代码如下:
<div :class="[activeClass, errorClass]"></div>
这里定义了 activeClass 和 errorClass 的 CSS 类名是 active 和 text-danger。
代码如下:
data: {
activeClass: 'active',
errorClass: 'text-danger'
}
渲染为
代码如下:
<div class="active text-danger"></div>
可以用混合的形式来绑定 class,即数组语法里写对象语法。所以 data 里的数据主要用于:
代码如下:
<div :class="[{ active: isActive }, errorClass]"></div>
这里定义了 errorClass 的 CSS 类名为 text-danger,并用 isActive 定义是否需要 active 类。
代码如下:
data: {
errorClass: 'text-danger',
isActive: true
}
渲染为
代码如下:
<div class="active text-danger"></div>
data 里的属性是定义 style 里的值。与 class 不一样,class 是定义是否要这个 class的。
代码如下:
<div :style="{ color: activeColor, fontSize: fontSize + 'px' }"></div>
这里定义了 style 里的 color 和 font-size 的值。
代码如下:
data: {
activeColor: 'red',
fontSize: 30
}
渲染为
代码如下:
<div style="color: red; font-size: 30px"></div>
可以绑定多个样式对象到 style 上
代码如下:
<div :style="[baseStyles, overridingStyles]"></div>
这里在 data 里用 styleObject 定义了 color 和 font-size,再用 overridingStyles 定义了 background 和 margin。然后在组件里用数组进行混合绑定。
代码如下:
data: {
styleObject: {
color: 'red',
fontSize: '13px'
},
overridingStyles: {
background: 'green',
margin: '13px'
}
}
渲染为
代码如下:
<div style="color: red; font-size: 13px; background: green; margin: 13px;"></div>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持四海网。
本文来自:http://www.q1010.com/184/7049-0.html
注:关于Vue 样式绑定的实现方法的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。
关键词:vue.js
四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。