美文网首页
虚拟 DOM 和 DOM diff

虚拟 DOM 和 DOM diff

作者: AuraAura | 来源:发表于2022-03-14 10:47 被阅读0次

1.虚拟 DOM

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

2.优点

  • 减少DOM操作(次数和范围)
    虚拟DOM可以将多次操作合并为一次,比如添加1000个节点,不是一次次添加DOM节点。(次数)
    借助DOM diff将多余的操作省略,比如添加1000个节点,根据DOM diff对比,其实只有10个是新的。(范围)
  • 跨平台
    虚拟DOM应用在小程序、iOS系统、安卓应用

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

相关文章

  • 虚拟dom和diff算法

    虚拟DOM和diff算法 diff:精细化比对最小量更新 真实DOM和虚拟DOM 虚拟DOM:用JavaScrip...

  • 虚拟 DOM 和 DOM diff

    visual Dom是什么? 虚拟DOM其实就是,像拥有类似dom的一系列属性的对象,包括:标签名,标签上的属性,...

  • 虚拟DOM和DOM diff

    DOM总结 虚拟DOM是什么 一个能代表DOM树的对象,通常含有标签名、标签上的属性、事件监听和子元素们,以及其它...

  • 虚拟DOM和DOM diff

    虚拟DOM是什么? 一个能代表DOM树的对象,通常含有标签名、标签上的属性、事件监听和子元素们,以及其他属性。 虚...

  • 虚拟 DOM 和 DOM diff

    概念 虚拟DOM 是什么:其实就是个js对象虚拟 dom 是相对于浏览器所渲染出来的真实 dom 的,在react...

  • 虚拟 DOM 和 DOM diff

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

  • Diff 算法、key

    概念 DOM diff 就是对比两棵虚拟 DOM 树的算法。当组件变化时,会得到一个新的虚拟 DOM,diff 算...

  • 面试题集(2)

    为什么虚拟dom会提高性能? 参考答案 虚拟dom相当于在js和真实dom中间加了一个缓存,利用dom diff算...

  • react VS Vue diff算法

    react diff diff算法的作用:数据更改,生成相应的虚拟DOM,与真实DOM作对比,通过diff算法,对...

  • 深入理解react中的虚拟DOM、diff算法

    文章结构: React中的虚拟DOM是什么? 虚拟DOM的简单实现(diff算法) 虚拟DOM的内部工作原理 Re...

网友评论

      本文标题:虚拟 DOM 和 DOM diff

      本文链接:https://www.haomeiwen.com/subject/sbqjdrtx.html