• 技术文章 >web前端 >Vue.js

    深入解析vue中的key,看看key到底能拿来干嘛!

    青灯夜游青灯夜游2021-12-24 10:56:53转载105
    key到底有什么用途?下面本篇文章给大家深度解析一下vue中的key,看看key到底能拿来干嘛,希望对大家有所帮助!

    vue中关于key的深度解析

    key到底有什么用途 ?

    面对这些云里雾里的概念, 先不要急, 看一遍有个印象, 接下来一步步来深度解析key到底拿来干嘛。【相关推荐:《vue.js教程》】

    1 vnode 虚拟节点

    vnode : virtual node, 虚拟节点

    还记得DOM树中的要素吗 ? 文档, 元素, 节点

    那什么是虚拟节点呢 ?

    简单来说, 要被vue渲染到页面上的节点, 就是虚拟节点

      <template id="my-app">
        <div class="title" style="font-size: 30px; color: red;">哈哈哈</div>
      </template>

    这里的div就是一个虚拟节点, 在vue中, 它以这种形式存在

        const vnode = {
          type: "div",
          props: {
            class: "title",
            style: {
              "font-size": "30px",
              color: "red",
            },
          },
          children: "哈哈哈",
        };

    不理解的地方可能是children这个属性, 因为现在div没有子元素, 因此值仅仅为"哈哈哈", 若有子元素, 那么就会是一直套娃套下去, 套到最后一个结点为止, 如

          children: [
            {
              // 子元素
            },
            {
              // 子元素
            }
          ],

    2 vDOM 虚拟DOM

    和真实DOM一样, 有真实节点就有真实DOM, 那么有虚拟节点, 就有虚拟DOM

    当然虚拟DOM tree也一样咯, 也有叫VNode tree的, 一个意思, 这个不需要纠结, 大概是下面这样

      <template id="my-app">
        <div>
          <div>
            <p></p>
            <p></p>
            <ul>
              <li></li>
              <li></li>
              <li></li>
            </ul>
          </div>
        </div>
      </template>

    转换成虚拟DOM树 :

    1.png

    虚拟DOM在渲染成真实DOM时, 不一定是完全一样的, 这里涉及到组件的问题, 后面有机会在讲

    3 渲染过程

    2.png

    4 案例 : 插入f

    理解完前面的后, 这里开始正题, 仅需一个案例, 就能全盘理解key的作用, 下面开始

    先看这个简单的案例(没加key)

        <ul>
          <li v-for="item in letters">{{item}}</li>
        </ul>
          data() {
            return {
              letters: ['a', 'b', 'c', 'd']
            }
          },
          methods: {
            insertF() {
              this.letters.splice(2, 0, 'f');
            }
          },

    可以看出, 该题的目的是想在ab与cd之间, 插入一个f

    理解了这个简单的案例后, 我们开始想, 有什么方法来插入到真实DOM中呢 ?

    有以下三种 :

    方法一(普通方法)

    3.png

    说明 : 直接把以前的dom删掉, 用新的vnode重新渲染一遍

    方法二(不带key的diff算法)

    4.png

    说明 : 这是不带key时, vue默认的diff算法, 对应的源码如图

    vue会通过判断语句, 来判断你是否带了key

    5.png

    下面是无key时的情况

    6.png

    然后查看patchUnkeyedChildren(), 就能查看diff算法的执行过程

    这里简单描述下 :

    方法三(带key的diff算法)

    7.png

    同理, 跟着方法二的步骤就能查看到patchKeyedChildren()方法

    这一种方法才是精髓, 开始复杂了

    总结 : 至此, 整个案例的流程已经完全过了一遍了, 本作者只能理解到这里, 该文结合了coderwhy的视频和自己的一些思考(视频来源 : https://ke.qq.com/course/3453141),因此很有可能有不对的地方, 欢迎大家踊跃批评与指正

    【相关推荐:《vue.js教程》】

    以上就是深入解析vue中的key,看看key到底能拿来干嘛!的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:掘金社区,如有侵犯,请联系admin@php.cn删除
    专题推荐:vue key
    上一篇:vue和echarts的区别是什么 下一篇:vue中replace的含义是什么

    相关文章推荐

    • 聊聊Vue3中路由,浅析路由配置方式• Ant Design Vue中如何让Textarea组件有“字数统计”功能• 什么是WeakMap?Vue3响应式源码中为什么用它作为缓存区?• vue2&vue3数据响应式原理分析及手动实现(实例详解)• 最系统的vue全套教程(详解及实例)• 聊聊Ant Design Vue中怎么实现省市穿梭框

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网