【Vue】v-for中:key中item.id与Index使用的区别

先说结论,推荐使用【:key="item.id"】而不是将数组下标当做唯一标识,前者能做到全部复用
场景:删除无序列表中的<li>标签

html 复制代码
<!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="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>
相关推荐
TeleostNaCl2 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
前端大卫3 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友3 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理5 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻5 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
mapbar_front6 小时前
在职场生存中如何做个不好惹的人
前端
牧杉-惊蛰6 小时前
纯flex布局来写瀑布流
前端·javascript·css
一袋米扛几楼987 小时前
【软件安全】什么是XSS(Cross-Site Scripting,跨站脚本)?
前端·安全·xss
向上的车轮7 小时前
Actix Web适合什么类型的Web应用?可以部署 Java 或 .NET 的应用程序?
java·前端·rust·.net
XiaoYu20027 小时前
第1章 核心竞争力和职业规划
前端·面试·程序员