vue class与style绑定

10 篇文章 0 订阅

介绍


元素的class和style属于attribute,所以可以用v-bind处理。而在v-bind用于classhestyle时,vue.js专门增强了一下,接受的表达式结果除了字符串,还要数组和对象。

绑定class

  1. 字符串语法:
<div  v-for="(item, index) in list" :class="'demo' + index"></div>

<div v-for="(item, index) in lists">
	<i :class="item.icon"></i>
</div>

data () {
	return {
		list: [],
		lists: [
			{ icon: 'icon-like' },
			{ icon: 'icon-new' },
			{ icon: 'icon-share' }
		]
	}
}
  1. 对象语法:
//对象表达式
<div  class="demo" :class="{'demo-red': isActive, 'demo-green': !isActive}"></div>

data () {
	return {
		isActive: true,
	}
}
//绑定一个数据中的对象
<div  class="demo" :class="demoClassInfo"></div>

data () {
	return {
		isActive: true,
		demoClassInfo: {
			'demo-red': isActive,
			'demo-green': !isActive
		}
	}
}
//绑定一个计算属性
<div  class="demo" :class="demoClassInfo"></div>

data () {
	return {
		count: 0,
	}
}
cmputed: {
	demoClassInfo() {
		return  {
			'demo-green': count > 0 && count <= 100  ? true :  false,
			'demo-red': count > 100 ? true :  false,
		}
	}
}
  1. 数组语法:
//三元表达式
<div  class="demo" :class="[ isActive ? 'demo-red' : 'demo-green' ]"></div>

data () {
	return {
		isActive: true,
	}
}
<div  class="demo" :class="[demoClass1, demoClass2]"></div>

data () {
	return {
		demoClass1: 'demo-color',
		demoClass2: 'demo-size',
	}
}

<div  class="demo" :class="demoClassList"></div>

data () {
	return {
		demoClassList: [ 'demo-color', 'demo-size'],
	}
}
//绑定一个计算属性
<div  class="demo" :class="demoClassInfo"></div>

data () {
	return {
		count: 0,
	}
}
cmputed: {
	demoClassInfo() {
		return  [
			count > 0 && count <= 100  ? 'demo-green' : '',
			count > 100 ? 'demo-red' : ''
		]
	}
}

绑定style

css语法可以使用驼峰式(camelCase)、短横分隔命名(kabab-case)

  1. 对象语法:
<div  class="demo" :style="color: demoColor, fontSize: demoFontSize / 100 + ''rem'"></div>

data () {
	return {
		demoColor: 'red',
		fontSize: 24
	}
}
<div  class="demo" :style="demoStyleInfo"></div>

 data () {
	return {
		demoStyleInfo:  {
			demoColor: 'red',
			fontSize: '0.24rem'
		}
	}
}
  1. 数组语法:
<div  class="demo" :style="[demoColor, demoSize]"></div>

 data () {
	return {
		demoStyleInfo:  {
			demoColor: 'color: red',
			demoSize: 'fontSize: 0.24rem'
		}
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值