为了账号安全,请及时绑定邮箱和手机立即绑定

vue循环出来的数据,怎么点击的时候,给当前的变色呢?

vue循环出来的数据,怎么点击的时候,给当前的变色呢?

繁星淼淼 2019-03-12 16:13:43
vue循环出来的数据,怎么点击的时候,给当前的变色呢?我页面是这样写的       <ol v-if="tooglezhi" class="ol_one">                        <li v-for="(item,key) in arr"                                @click="son(item,key)"><span></span>{{item}}</li>                    </ol>在data中我想要的效果是我点击其中一个的时候 其中的变色,怎么用vue实现呢 我之前一直是用jquery写的
查看完整描述

4 回答

?
哆啦的时光机

TA贡献1779条经验 获得超6个赞

获取到的data,你可以自定义个变量,isActive,默认都是false,当你点击的时候,给当前这个isActive赋值为true就可以了,li上在绑定一个class名
<li v-for="(item,key) in arr" click="son(item,key)" :class="{'active': item.isActive}"><span></span>{{item}}</li>

查看完整回答
反对 回复 2019-03-23
?
呼啦一阵风

TA贡献1802条经验 获得超6个赞

data:index:0



<li v-for="(item,key) in arr" @click="key=index" :class="key==index?'active':''"><span></span>{{item}}</li>


查看完整回答
反对 回复 2019-03-23
?
慕田峪7331174

TA贡献1828条经验 获得超13个赞

<div :class="{active: 'currentKey === key'}"></div>

data() {

    currentKey: 0

},

methods: {

    son(key) {

        this.currentKey =  key

    }

}


查看完整回答
反对 回复 2019-03-23
  • 4 回答
  • 0 关注
  • 4447 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号