从vue源码中看diff算法

编程入门 行业动态 更新时间:2024-10-27 14:25:09

从vue源码<a href=https://www.elefans.com/category/jswz/34/1569997.html style=中看diff算法"/>

从vue源码中看diff算法

一、v-for必须要指定key,其作用是什么?

在源码中有一个函数为,其中就是通过判断两个vnode的type和key进行判断,如果这两个属性相同,那么这两个vnode就是相同,所以在设置key的时候也不可以设置为object等无法通过三等号判断的类型。

export function isSameVNodeType(n1: VNode, n2: VNode): boolean {return n1.type === n2.type && n1.key === n2.key
}

二、diff分为五种对比策略

源码在packages/runtime-core/src/renderer.ts的patchKeyedChildren()函数。

1、从前向后
2、从后向前
3、新节点 > 旧节点
4、旧节 > 新节点
5、乱序

更多推荐

从vue源码中看diff算法

本文发布于:2023-11-15 22:34:32,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1607715.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:中看   算法   源码   vue   diff

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!