美文网首页
React虚拟DOM浅析

React虚拟DOM浅析

作者: 魂斗驴 | 来源:发表于2021-02-04 09:13 被阅读0次

如果您正在使用React或学习React,那么您一定听说过“虚拟DOM”一词。现在什么是虚拟DOM?为什么React使用它?

真实DOM
首先,DOM代表“文档对象模型”。DOM用简单的语言表示应用程序的UI。每当应用程序UI的状态发生变化时,DOM都会更新以表示该变化。现在,问题是经常操纵DOM影响性能,使其变慢。

是什么导致DOM操作缓慢?
DOM表示为树数据结构。因此,DOM的更改和更新很快。但是在更改之后,必须重新渲染已更新的元素及其子元素以更新应用程序UI。UI的重新渲染或重新绘制使它变慢。因此,您拥有的UI组件越多,DOM更新的成本就越高,因为每次DOM更新都需要重新渲染它们。

虚拟DOM

那就是虚拟DOM概念出现的地方,并且其性能要比真实DOM好得多。虚拟DOM只是DOM的虚拟表示。每当我们的应用程序状态更改时,虚拟DOM就会更新,而不是真实DOM。

好吧,您可能会问:“虚拟DOM是否与真实DOM所做的相同,这听起来像是双重工作?这比仅仅更新真实的DOM还要快吗?”

答案是虚拟DOM更快,更高效,这就是原因。

虚拟DOM如何更快?

将新元素添加到UI时,将创建表示为树的虚拟DOM。每个元素都是该树上的一个节点。如果这些元素中任何一个的状态改变,那么将创建一个新的虚拟DOM树。然后将该树与先前的虚拟DOM树进行比较或“差异化”。

完成此操作后,虚拟DOM将计算出最佳方法以对真实DOM进行这些更改。这样可以确保对实际DOM的操作最少。因此,降低了更新实际DOM的性能成本。

下图显示了虚拟DOM树和差异化过程。


虚拟DOM

红色圆圈表示已更改的节点。这些节点表示状态已更改的UI元素。然后计算虚拟DOM树的先前版本与当前虚拟DOM树之间的差异。然后重新渲染整个父子树以提供更新的UI。然后将此更新的树批量更新为真实的DOM。

React如何使用虚拟DOM

现在您对虚拟DOM是什么以及它如何对您的应用程序性能有所了解了,让我们了解一下React如何利用虚拟DOM。

在React中,每个UI块都是一个组件,每个组件都有一个状态。React遵循可观察的模式,并监听状态变化。当组件的状态改变时,React更新虚拟DOM树。虚拟DOM更新后,React然后将虚拟DOM的当前版本与虚拟DOM的先前版本进行比较。此过程称为“差异化”。

一旦React知道哪些虚拟DOM对象已更改,然后React就会在真实DOM中仅 更新那些对象。与直接操作真实DOM相比,这使性能好得多。这使React作为高性能JavaScript库脱颖而出。

简而言之,您可以告诉React您希望UI处于什么状态,并确保DOM匹配该状态。这里最大的好处是,作为开发人员,您将不需要知道如何在后台进行属性操纵,事件处理或手动DOM更新。

所有这些细节都是从React开发人员那里抽象出来的。您需要做的就是在需要时更新组件的状态,React负责其余的工作。这样可以确保在使用React时获得卓越的开发人员体验。

React render()函数

render()是更新和渲染UI的位置。render()是React中必需的生命周期方法。render()函数是创建React元素树的入口点。当组件中的状态或道具更新时,render()将返回不同的React元素树。如果在组件内使用setState() ,React会立即检测到状态更改并重新渲染组件。

然后,React找出如何有效地更新UI以匹配最新的树更改。

这是当React首先更新其虚拟DOM并仅更新实际DOM中已更改的对象时。

批量更新

React遵循批处理更新机制来更新实际DOM。因此,导致性能提高。这意味着对真实DOM的更新将分批发送,而不是针对状态的每个单个更改发送更新。

UI的重新绘制是最昂贵的部分,React有效地确保了真正的DOM仅接收批量更新来重新绘制UI

总结

  • 频繁的DOM操作昂贵且性能沉重。
  • 虚拟DOM是真实DOM的虚拟表示。
  • 状态发生变化时,将更新虚拟DOM,并比较虚拟DOM的先前版本和当前版本。这称为diff
  • 然后,虚拟DOM将批量更新发送到真实DOM以更新UI。
  • React使用虚拟DOM来增强其性能。
  • 它使用可观察对象来检测状态和道具更改。
  • React使用高效的差异算法来比较虚拟DOM的版本。
  • 然后,确保将批处理的更新发送到真实的DOM,以重新绘制或重新呈现UI。

参考

React Virtual DOM Explained in Simple English

相关文章

网友评论

      本文标题:React虚拟DOM浅析

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