vue中控制v-for循环出来的某一个列表项的显示隐藏切换

第一种方法:通过给每条数据添加字段的方法

给每一项点击的地方添加一个点击事件,把当前的列表项作为参数传递过去

在methods里面写点击事件:

首先判断列表项有没有这个字段,没有的话就通过this.$set添加字段,然后进行取反,有这个字段的话直接取反。

this.$set(你要添加数据的数组或对象, '字段名称', 字段值)
     
     

最后通过v-show控制代码块的显示隐藏

 

第二种方法:在data里面设置一个属性

在data里面设置一个属性thisIndex,给一个初始值为-1或者null:

写点击事件的时候,将当前项的下标作为参数传过去:

在点击事件中,当thisIndex为空时则将当前项的下标赋值给它,当不为空时则将thisIndex清空即可:

但是这种方法有个bug,只能控制一个元素的显示隐藏,thisIndex毕竟还是全局的,当要同时展开两个时就会出问题,所以最好还是使用第一种给数据加字段的方法。

  • 8
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值