Duplicate keys detected: This may cause an update error.【Vue遍历渲染报错的解决】

今天在写项目时,写到一个嵌套评论的遍历时,控制台出现了一个报错信息,但是并不影响页面的渲染,然后一看这个错的原因是 key值重复,那么问题的解决方式就很简单了。(vue for循环读取key值时, key需要是唯一的,如果key值重复会导致报错,影响页面渲染卡顿。)

① 原代码:

html 复制代码
<div  v-for="item in commentList" :key="item.id">
    <img :src="item.avatar" alt="" >
    <div style="flex: 1">
      <!--一级评论-->
      <div style="margin-bottom: 10px">
        <div >{{ item.userName }}</div>
        <div >{{ item.content }}</div>
        <div >{{ item.time }}</div>
      </div>
      <!--子级评论-->
      <div v-for="sub in item.children" :key="sub.id">
        <img :src="sub.avatar" alt="" >
        <div >
          <div >{{ sub.userName }} <span  v-if="sub.replyUser !== item.userName">回复  {{ sub.replyUser }}</span></div>
          <div>{{ sub.content }}</div>
          <div >{{ sub.time }}</div>
        </div>
      </div>
    </div>
  </div>

② 新代码:

html 复制代码
<div  v-for="item in commentList" :key="item.id">
    <img :src="item.avatar" alt="" >
    <div style="flex: 1">
      <!--一级评论-->
      <div style="margin-bottom: 10px">
        <div >{{ item.userName }}</div>
        <div >{{ item.content }}</div>
        <div >{{ item.time }}</div>
      </div>
      <!--子级评论-->
      <div v-for="(sub,i) in item.children" :key="sub.id+i">
        <img :src="sub.avatar" alt="" >
        <div >
          <div >{{ sub.userName }} <span  v-if="sub.replyUser !== item.userName">回复  {{ sub.replyUser }}</span></div>
          <div>{{ sub.content }}</div>
          <div >{{ sub.time }}</div>
        </div>
      </div>
    </div>
  </div>

为什么for循环后要加key值,否则会爆红,会产生什么影响?

for循环读取key值时, key需要是唯一的,如果key值重复会导致报错,影响页面渲染卡顿。

解决方式

只需要遍历时将key加上一个随机值即可,最简单就是同时遍历出索引与key相加
<div v-for="(item, i) in items2" :key="'A'+ i"></div>

相关推荐
恋猫de小郭11 分钟前
Flutter 小技巧之:实现 iOS 26 的 “液态玻璃”
android·前端·flutter
糖墨夕15 分钟前
Trae还能将Figma 设计稿转化为前端代码
前端·trae
程序猿小D16 分钟前
第26节 Node.js 事件
服务器·前端·javascript·node.js·编辑器·ecmascript·vim
天天打码17 分钟前
Bootstrap Table开源的企业级数据表格集成
前端·开源·bootstrap
Allen Bright19 分钟前
【CSS-8】深入理解CSS选择器权重:掌握样式优先级的关键
前端·css
hnlucky21 分钟前
安装vue的教程——Windows Node.js Vue项目搭建
前端·javascript·vue.js·windows·node.js
余道各努力,千里自同风34 分钟前
CSS“多列布局”
前端·css·html
苏_Berlvy37 分钟前
javascript中Cookie、BOM、DOM的使用
javascript
Keya40 分钟前
使用 tinypng 脚本打包为exe 进行压缩图片
前端·python·程序员
wordbaby1 小时前
React Router 的 handle 和 useMatches 的作用、场景和联系
前端·react.js