10 分钟搞懂 key 对vue3 diff性能提升

10分钟 搞懂 key 对 vue3 diff性能的提升(真的10分钟)

Talk is cheap, show you the code
点击按钮时会在中间插入一个 f
在这里插入图片描述

我们可以确定的是,这次更新对于ul和button是不需要进行的,需
要更新的是我们li的列表:

  • 在 vue 中,对于相同父元素的子节点并不会重新渲染整个列表
  • 因为对于列表中的a、b、c、d 它们都是没有变化的
  • 在操作真实 DOM 的时候,我们只需要在中间插入一个 f 的 li 即可

那么Vue中对于列表的更新究竟是如何操作的呢?
Vue事实上会对于有key和没有key会调用两个不同的方法

  • 事实上会对于有key和没有key会调用两个不同的方法
  • 有key,那么就使用 patchKeyedChildren方法
  • 没有key,那么久使用 patchUnkeyedChildren方法
    在这里插入图片描述

没有 key 的源码操作

在这里插入图片描述

没有 key 的过程如下

在这里插入图片描述
我们会发现上面的diff算法效率并不高

  • c和d来说它们事实上并不需要有任何的改动
  • 但是因为 c 被 f 占了,所有后续的内容都要依次改动,并且最后进行新增;

有 key 的源码操作

在这里插入图片描述

有 key 的diff 图解如下

在这里插入图片描述
第一步的操作是从头开始进行遍历、比较

  • a和b是一致的会继续进行比较
  • c和f因为key不一致,所以就会break跳出循环

在这里插入图片描述
第二步的操作是从尾部开始进行遍历、比较
在这里插入图片描述
第三步是如果旧节点遍历完毕,但是依然有新的节点,那么就新增节点
在这里插入图片描述
第四步是如果新的节点遍历完毕,但是依然有旧的节点,那么就移除旧节点
在这里插入图片描述
第五步是最特色的情况,中间还有很多未知的或者乱序的节点

Vue在进行diff算法的时候,会尽量利用我们的key来进行优化操作

  • 在没有key的时候我们的效率是非常低效的
  • 在进行插入或者重置顺序的时候,保持相同的key可以让diff算法更加的高效
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值