Vue 里style、class 内联三元表达式和img里src处理

首先是style和class使用三元表达式处理:

通常给class绑定个对象,就可以动态的切换样式了。(data中定义isActive的true、false)

 

<div :class="{ active: isActive }">hello</div>
handleClick(){ this.isActive = !this.isActive }

推荐、不加{}就算是加字符串,最好绑定class用[]、{判断},style用{}

<i class="iconfont "  :class="[current=='0'?'class1':'class2']"></i> 

v-bind:style="{样式名:'样式值'}" 必须是字符串形式:

<span v-bind:style="{display:isActive ? 'block':'none'}">hello</span>
<div :style="{width:width,height:height}"></div>

数组形式:

<div :class='["classify",current=="0" ? "active" : ""]'  @click='current=0'>xx</div>
<div :class='["classify", isActive? "active" : ""]'>xx</div>
注意:数组中的classify如果不加引号的话,代表的是data中的一项,并不是类名,将classify加上双引号,变成字符串就可以变成类名

字符串拼接:

<div :class="'classify'+(current=='0'?' active':'')"  @click='current=0'>xx</div>
注意:active前要加一个空格(必须有),字符串拼接时,两个字符串之间要有空格
<button class="tk" v-show="(active==0 || active==1) || active==2">退款</button>

处理img动态scr使用三元运算符是不行的,其实vue是将图片转换成base64的,所有我们最好的方式是用v-if:

 <img v-if="aimsImageurl"src=".~assets/img/tvscreen/arrow04.png'' />
 <img v-else src="~assets/img/tvscreen/arrow03.png" />

谢谢,希望对你有所帮助

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值