解决vue中报错 Duplicate keys detected:‘1‘. This may cause an update error.

报错截图:

在这里插入图片描述


报错原因:

通过上图的报错信息我们不难看出,报错的主要原因出现在 key 值上,报错的意思大概是检测到重复的 key 值,通俗来讲就是你的 key 值不是唯一的。


解决方案:

问题的根源找到了,解决起来就会很简明扼要了,其实项目中出现这种报错多为以下这两种情况:

第一种情况:

for 循环的 key 值不为唯一性。

<template>
  <div>
    <div v-for="(item,index) in listData" :key="item.idx">{{item.name}}</div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      listData: [
        { idx: "0", name: "数据1" },
        { idx: "0", name: "数据2" },
        { idx: "1", name: "数据3" },
      ],
    };
  },
};
</script>

第二种情况:

页面上有两个 for 循环同一个数组,导致 key 重复。

<template>
  <div>
    <div v-for="(item,index) in listData" :key="item.idx">{{item.name}}</div>
    <div v-for="(item,index) in listData" :key="item.idx">{{item.name}}</div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      listData: [
        { idx: "0", name: "数据1" },
        { idx: "1", name: "数据2" },
        { idx: "2", name: "数据3" },
      ],
    };
  },
};
</script>

以上即为两种常见的引起报错的情况,下面教你如何解决这个问题。

<template>
  <div>
    <div v-for="(item,index) in listData" :key="index">{{item.name}}</div>
  </div>
</template>

<script>  
export default {
  data() {
    return {
      listData: [
        { idx: "0", name: "数据1" },
        { idx: "0", name: "数据2" },
        { idx: "1", name: "数据3" },
      ],
    };
  },
};
</script>

第一种情况我们可以直接将 key 值指定为 for 循环的 index 值,这样即可解决 key 重复的问题。


<template>
  <div>
    <div v-for="(item,index) in listData" :key="item.idx + 1">{{item.name}}</div>
    <div v-for="(item,index) in listData" :key="item.idx">{{item.name}}</div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      listData: [
        { idx: "0", name: "数据1" },
        { idx: "1", name: "数据2" },
        { idx: "2", name: "数据3" },
      ],
    };
  },
};
</script>

第二种情况可以看到我们将第一个 for 循环中的 key 值拼接了一个数字,这样两个 for 循环中的 key 值都具有唯一性,故不会报错。其实不只是数字,字符串或者其它的标记都可以区别 key 值得唯一性,感兴趣的同学可以下去试一试。

报错信息"Duplicate keys detected: 'trayGoods'. This may cause an update error."表示在代码存在重复的键值'trayGoods',这可能会导致更新错误。解决此问题的方法是生成唯一的id来替代重复的键值。可以使用nanoid库的nanoid函数生成一个唯一id,例如:const id = nanoid()。此函数默认生成长度为21的字符串作为id,也可以通过传递参数来指定生成字符串的长度,例如const id = nanoid(11)。通过这样的方式生成唯一的id,可以避免重复键值的问题,并确保代码运行时不会出现更新错误。 <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [[Vue warn]: Duplicate keys detected: ‘2‘. This may cause an update error.](https://blog.csdn.net/qq_45284875/article/details/130112581)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [vue控制台报错Duplicate keys detected: ‘xxxx‘. This may cause an update error.解决方案](https://blog.csdn.net/m0_61726249/article/details/131228855)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [UltraEdit-32](https://download.csdn.net/download/wangchao_whc/860271)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

水星记_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值