v-for 遍历数组点击动态绑定样式

本文介绍了在Vue开发中遇到的使用v-for遍历数组并动态绑定样式时遇到的问题。错误地使用全局变量导致所有元素同时被选中。为了解决这个问题,提出了一种解决方案:通过创建独立的变量存储当前选中项的索引,从而实现唯一的选择状态。这种方法避免了污染数据源,实现了单个元素的样式绑定。欢迎读者提供更好的建议。
摘要由CSDN通过智能技术生成

这可能是一个对于任何js开发者来说都非常简单的问题,或者根本谈不上被叫做“问题”,“基操”而已。但是,很遗憾,我为此开了个篇幅简略记录下它,因为这是我处于前端开发基础阶段数次阻滞过我的问题,以下暂提供一种解决方案,后续可能补充。

这类问题多见于单页面应用(SPA)中的侧边栏、表格列等,当我曾拿到这个需求时,我以为我能用Vue中介绍的Class动态绑定来解决,事实上的确如此,但我用错了,请看我错误的解决方法:

HTML

<template>
<!-- 点击某个绑定样式 -->
  <ul>
    <li v-for="(data, index) in formData" :key="data.id" :class="{active: isActive}" @click="currentInfo(data, index)">name: {
  {data.name}},age: {
  {data.age}}
    </li>
  </ul>

</template>
JavaScript

<script>
export default {
    name: 'classActive'
    data() {
        return {
            isActive: false,    // 用来判断active样式类是否显示
            formData: [{
                id: 1,
  
  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值