vue绑定style和class 对象写法

适用于:要绑定多个样式,个数确定,名字也确定,但不确定用不用。

绑定 class 样式【对象写法】:

css 复制代码
.box{
	width: 100px;
	height: 100px;
}
.aqua{
	background-color: aqua;
}
.border{
	border: 20px solid red;
}
.radius{
	border-radius: 25px;
}
html 复制代码
<div id="APP">
	<div class="box" :class="classObj">多个class样式</div>
</div>
javascript 复制代码
const vm = new Vue({
	el: "#APP",
	data(){
		return {
			classObj:{
				aqua: true,
				border: false,
				radius:false
			}
		}
	}
});

注:对象写法中的键名必须是 class 类名,值如果为 true 表示使用,如果为 false 表示不使用。当然我们也可以动态修改它的值,选择是否使用。

对象写法也可以直接写在标签中,例:

css 复制代码
.box{
	width: 100px;
	height: 100px;
}
.aqua{
	background-color: aqua;
}
.border{
	border: 20px solid red;
}
.radius{
	border-radius: 25px;
}
html 复制代码
<div id="APP">
	<div class="box" :class="{aqua:a, border:b, radius:c}">多个class样式</div>
</div>

注:效果与上边的示例相同,a、b、c 都是变量,控制是否使用某个 class 样式。

绑定 style 样式【对象写法】 :

html 复制代码
<div id="APP">
	<div :style="styleObj">绑定style样式</div>
</div>
javascript 复制代码
const vm = new Vue({
	el: "#APP",
	data(){
		return {
			styleObj:{
				width: '100px',
				height: '100px',
				backgroundColor: "aqua"
			}
		}
	}
});

注:动态绑定 style 样式时,属性必须使用小驼峰命名法,例如:backgroundColor 。

绑定 style 样式【数组写法】:

html 复制代码
<div id="APP">
	<div :style="styleArr">绑定style样式</div>
</div>
javascript 复制代码
const vm = new Vue({
	el: "#APP",
	data(){
		return {
			styleArr:[
				{
					width: "100px",
					height: "100px"
				},
				{
					backgroundColor: "aqua",
					border:"20px solid red"
				}
			]
		}
	}
});

注:使用数组写法绑定 style 样式时,数组其实是由多个 样式对象 组成的。

数组写法也可以直接写在标签中,与上面示例的效果相同。

html 复制代码
<div id="APP">
	<div :style="[styleObj1,styleObj2]">绑定style样式</div>
</div>
javascript 复制代码
const vm = new Vue({
	el: "#APP",
	data(){
		return {
			styleObj1:{
				width: "100px",
				height: "100px"
			},
			styleObj2:{
				backgroundColor: "aqua",
				border:"20px solid red"
			}
		}
	}
});

原创作者:吴小糖

创作时间:2023.10.13

相关推荐
玩电脑的辣条哥2 小时前
Python如何播放本地音乐并在web页面播放
开发语言·前端·python
ew452182 小时前
ElementUI表格表头自定义添加checkbox,点击选中样式不生效
前端·javascript·elementui
suibian52352 小时前
AI时代:前端开发的职业发展路径拓宽
前端·人工智能
画月的亮2 小时前
element-ui 使用过程中遇到的一些问题及解决方法
javascript·vue.js·ui
Moon.92 小时前
el-table的hasChildren不生效?子级没数据还显示箭头号?树形数据无法展开和收缩
前端·vue.js·html
m0_526119402 小时前
点击el-dialog弹框跳到其他页面浏览器的滚动条消失了多了 el-popup-parent--hidden
javascript·vue.js·elementui
垚垚 Securify 前沿站2 小时前
深入了解 AppScan 工具的使用:筑牢 Web 应用安全防线
运维·前端·网络·安全·web安全·系统安全
工业甲酰苯胺5 小时前
Vue3 基础概念与环境搭建
前端·javascript·vue.js
lyj1689975 小时前
el-tree选中数据重组成树
javascript·vue.js·elementui
mosquito_lover16 小时前
怎么把pyqt界面做的像web一样漂亮
前端·python·pyqt