虚拟 DOM 和 DOM diff

2022-03-14  本文已影响0人  AuraAura

1.虚拟 DOM

与页面DOM元素对应的对象。包含标签名、标签上的属性、事件监听及其子元素。本质是一个JS对象。

2.优点

3.缺点

需要额外的创建函数来创建,React使用createElement,Vue使用h函数,依赖打包工具构建js文件

4.DOM diff

一个函数,运行DOM的操作,对比新旧DOM 树然后更新。
patches = patch(oldVNode,newVNode)

Tree diff
将新旧两棵树逐层进行对比,查找更新节点
更新节点为组件-Component diff
更新节点为标签-Element diff
Component diff
如果节点是组件,就先看组件类型
类型不同直接替换(删除旧的)
类型相同则只更新属性
然后深入组件做 Tree diff(递归)
Element diff
如果节点是原生标签,则看标签名
标签名不同直接替换,相同则只更新属性
然后进入标签后代做 Tree diff(递归)

5.DOM diff 的优点

可以减少DOM操作

6.DOM diff 的问题(key)

在同级节点对比有bug,在同级节点更新时无法判断是删除了子节点p,还是更新了子节点p,给他们添加唯一值key来标识就可以解决。不要用index来作为key值,在增删DOM节点时,index作为数组的下标是不变的,比如[1,2,3]变成[1,3],下标2始终存在。

实际是删除节点p,代码会认为更新节点p且删除节点span.png
上一篇下一篇

猜你喜欢

热点阅读