uniapp之动态绑定class和style样式(vue.js)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了uniapp之动态绑定class和style样式(vue.js)相关的知识,希望对你有一定的参考价值。

参考技术A (1) 动态class样式

(2) 图片动态资源 :src
eg1:后台返回图片的相对路径,需拼接完整的网络地址

eg2:动态图片资源和动态class样式

8.绑定class样式和style样式

绑定样式:

  1. class样式

写法

:class=“xxx” xxx可以是字符串、对象、数组

  • 字符串写法适用于:类名不确定,要动态获取。
  • 对象写法适用于:要绑定多个样式,个数不确定,名字也不确定。
  • 数组写法适用于:要绑定多个样式,个数确定,名字也确定,但不确定用不用。
  1. style样式

    :style="fontSize: xxx“其中xxx是动态值。
    :style=”[a,b]"其中a、b是样式对象(样式对象即CSS中存在的属性)。

注意:实际开发中绑定class样式较多

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8" />
		<title>绑定样式</title>
		<style>
			.basic
				width: 400px;
				height: 100px;
				border: 1px solid black;
			
			
			.happy
				border: 4px solid red;;
				background-color: rgba(255, 255, 0, 0.644);
				background: linear-gradient(30deg,yellow,pink,orange,yellow);
			
			.sad
				border: 4px dashed rgb(2, 197, 2);
				background-color: gray;
			
			.normal
				background-color: skyblue;
			

			.atguigu1
				background-color: yellowgreen;
			
			.atguigu2
				font-size: 30px;
				text-shadow:2px 2px 10px red;
			
			.atguigu3
				border-radius: 20px;
			
		</style>
		<script type="text/javascript" src="../js/vue.js"></script>
	</head>
	<body>
		<div id="root">
			<!-- 绑定class样式--字符串写法,适用于:样式的类名不确定,需要动态指定 -->
			<div class="basic" :class="mood" @click="changeMood">name</div> <br/><br/>

			<!-- 绑定class样式--数组写法,适用于:要绑定的样式个数不确定、名字也不确定 -->
			<div class="basic" :class="classArr">name</div> <br/><br/>

			<!-- 绑定class样式--对象写法,适用于:要绑定的样式个数确定、名字也确定,但要动态决定用不用 -->
			<div class="basic" :class="classObj">name</div> <br/><br/>

			<!-- 绑定style样式--对象写法 -->
			<div class="basic" :style="styleObj">name</div> <br/><br/>
			<!-- 绑定style样式--数组写法 -->
			<div class="basic" :style="styleArr">name</div>
		</div>
	</body>

	<script type="text/javascript">
		Vue.config.productionTip = false
		
		const vm = new Vue(
			el:'#root',
			data:
				name:'尚硅谷',
				mood:'normal',
				classArr:['atguigu1','atguigu2','atguigu3'],
				classObj:
					atguigu1:false,
					atguigu2:false,
				,
				styleObj:
					fontSize: '40px',
					color:'red',
				,
				styleObj2:
					backgroundColor:'orange'
				,
				styleArr:[
					
						fontSize: '40px',
						color:'blue',
					,
					
						backgroundColor:'gray'
					
				]
			,
			methods: 
				changeMood()
					const arr = ['happy','sad','normal']
					const index = Math.floor(Math.random()*3)
					this.mood = arr[index]
				
			,
		)
	</script>
	
</html>

以上是关于uniapp之动态绑定class和style样式(vue.js)的主要内容,如果未能解决你的问题,请参考以下文章

VUE强制绑定class和style

vue中,动态绑定样式——动态绑定style写法 & 动态class写法

vue动态绑定class

vue中的class与style绑定

Vue知识整理9:class与style绑定

8.绑定class样式和style样式