Vue v-for中:key中item.id与Index使用的区别解析
更新时间:2024年02月21日 11:07:23 作者:Oneforlove_twoforjob
这篇文章主要介绍了Vue v-for中:key中item.id与Index使用的区别解析,推荐使用【:key="item.id"】而不是将数组下标当做唯一标识,前者能做到全部复用,本文给大家详细讲解,感兴趣的朋友跟随小编一起看看吧
先说结论,推荐使用【:key="item.id"】而不是将数组下标当做唯一标识,前者能做到全部复用
场景:删除无序列表中的<li>标签
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>创建一个Vue实例</title> <script src="https://cdn.jsdelivr.net/npm/vue@2.7.16/dist/vue.js"></script> <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet" integrity="sha384-GLhlTQ8iRABdZLl6O3oVMWSktQOp6b7In1Zl3/Jr59b6EGGoI1aFkw7cmDA6j6gD" crossorigin="anonymous"> <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/js/bootstrap.bundle.min.js" integrity="sha384-/mhDoLbDldZc3qpsJHpLogda//BVZbgYuw6kof4u2FrCedxOtgRZDTHgHUhOCVim" crossorigin="anonymous"></script> </head> <body> <div class="container"> <div id="app"> <!-- 事件:做<li>标签的删除功能,根据class的id删除, 此案例删除class="3"的标签 --> <!-- 原代码 --> <li class="1">1</li> <li class="2">2</li> <li class="3">3</li> <li class="4">4</li> <li class="5">5</li> <!-- 1.使用item.id做:key唯一标识符 --> <!-- 删除3后,变成 --> <li class="1">1</li> <li class="2">2</li> <li class="4">4</li> <li class="5">5</li> <!-- vue开始将剩下的四个<li>与源代码的五个<li>进行匹配 使用的是diff算法对比新旧虚拟DOM 由于精准删除3,1和2直接代码复用,4和5发现class和内容均能匹配上 将class重新排列 1234 则映射出新的组合,如下: --> <li class="1">1</li> <li class="2">2</li> <li class="3">4</li> <li class="4">5</li> <!-- ========================================================================= --> <!-- 2.使用index做:key唯一标识符 --> <!-- 删除3后,index数组下标会发生改变,变成 --> <li class="1">1</li> <li class="2">2</li> <li class="3">4</li> <li class="4">5</li> <!-- Vue将内容为4的li与内容为3的对比,发现匹配不上,删除3标签 再将内容为5的li与内容为4的对比,也匹配不上,又删除4标签 --> <!-- ========================================================================--> <!-- 总结:使用index很多情况不能代码复用,强制更新元素,影响性能 --> </div> </div> <script> const app = new Vue({ el: '#app', data:{ }, methods:{ } }) </script> </body> </html>
到此这篇关于Vue v-for中:key中item.id与Index使用的区别的文章就介绍到这了,更多相关vue item.id与Index使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
详解如何解决vue开发请求数据跨域的问题(基于浏览器的配置解决)
这篇文章主要介绍了详解如何解决vue开发请求数据跨域的问题(基于浏览器的配置解决),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-11-11Vue3.3 + TS4构建实现ElementPlus功能的组件库示例
Vue.js 是目前最盛行的前端框架之一,而 TypeScript 则是一种静态类型言语,它能够让开发人员在编写代码时愈加平安和高效,本文将引见如何运用 Vue.js 3.3 和 TypeScript 4 构建一个自主打造媲美 ElementPlus 的组件库2023-10-10elementui Select选择器嵌套tree实现TreeSelect方式
这篇文章主要介绍了elementui Select选择器嵌套tree实现TreeSelect方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-10-10Vue3 $emit用法指南(含选项API、组合API及 setup 语法糖)
这篇文章主要介绍了Vue3 $emit用法指南,使用 emit,我们可以触发事件并将数据传递到组件的层次结构中,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下2022-07-07
最新评论