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项目axios请求头更改Content-Type操作

    VUE项目axios请求头更改Content-Type操作

    这篇文章主要介绍了VUE项目axios请求头更改Content-Type操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • 详解如何解决vue开发请求数据跨域的问题(基于浏览器的配置解决)

    详解如何解决vue开发请求数据跨域的问题(基于浏览器的配置解决)

    这篇文章主要介绍了详解如何解决vue开发请求数据跨域的问题(基于浏览器的配置解决),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • TDesign在vitest的实践示例详解

    TDesign在vitest的实践示例详解

    这篇文章主要为大家介绍了TDesign在vitest的实践示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • Vue3.3 + TS4构建实现ElementPlus功能的组件库示例

    Vue3.3 + TS4构建实现ElementPlus功能的组件库示例

    Vue.js 是目前最盛行的前端框架之一,而 TypeScript 则是一种静态类型言语,它能够让开发人员在编写代码时愈加平安和高效,本文将引见如何运用 Vue.js 3.3 和 TypeScript 4 构建一个自主打造媲美 ElementPlus 的组件库
    2023-10-10
  • elementui Select选择器嵌套tree实现TreeSelect方式

    elementui Select选择器嵌套tree实现TreeSelect方式

    这篇文章主要介绍了elementui Select选择器嵌套tree实现TreeSelect方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • Vue3 $emit用法指南(含选项API、组合API及 setup 语法糖)

    Vue3 $emit用法指南(含选项API、组合API及 setup 语法糖)

    这篇文章主要介绍了Vue3 $emit用法指南,使用 emit,我们可以触发事件并将数据传递到组件的层次结构中,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-07-07
  • Vue使用konva实现一个简便的流程图

    Vue使用konva实现一个简便的流程图

    日常开发中我们可能碰到流程图的需求,实现流程图的库有很多,如果我们想要实现一个简便的流程图可以使用konva库来实现,下面我们就来看一下具体的实现过程,需要的朋友可以参考下
    2023-08-08
  • 浅谈v-for 和 v-if 并用时筛选条件方法

    浅谈v-for 和 v-if 并用时筛选条件方法

    今天小编就为大家分享一篇浅谈v-for 和 v-if 并用时筛选条件方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • Vue中的异步组件函数实现代码

    Vue中的异步组件函数实现代码

    这篇文章主要介绍了Vue中的异步组件函数实现代码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-07-07
  • 深入浅析Vue中的Prop

    深入浅析Vue中的Prop

    Prop的基本用法很简单,只需要在子组件的Vue实例中定义该属性并把值设为目标属性的数组即可。这篇文章主要介绍了Vue中的Prop ,需要的朋友可以参考下
    2018-06-06

最新评论