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>

相关推荐
Sunlightʊə35 分钟前
2.登录页测试用例
运维·服务器·前端·功能测试·单元测试
Code Crafter1 小时前
ES6-ES14 新特性速查
前端·ecmascript·es6
Lhuu(重开版1 小时前
CSS从0到1
前端·css·tensorflow
CDwenhuohuo2 小时前
微信小程序里用 setData() 修改数据并打印输出 的几种写法
javascript·微信小程序·小程序
不说别的就是很菜3 小时前
【前端面试】HTML篇
前端·html
前端一小卒3 小时前
生产环境Sourcemap策略:从苹果事故看前端构建安全架构设计
前端·javascript
im_AMBER3 小时前
React 18
前端·javascript·笔记·学习·react.js·前端框架
老前端的功夫3 小时前
Vue2中key的深度解析:Diff算法的性能优化之道
前端·javascript·vue.js·算法·性能优化
集成显卡3 小时前
AI取名大师 | PM2 部署 Bun.js 应用及配置 Let‘s Encrypt 免费 HTTPS 证书
开发语言·javascript·人工智能
han_3 小时前
前端高频面试题之Vue(高级篇)
前端·vue.js·面试