Quiz

What is virtual DOM in React?

Topics
React
在GitHub上编辑

TL;DR

The virtual DOM in React is a lightweight copy of the actual DOM. It allows React to efficiently update the UI by comparing the virtual DOM with the real DOM and only making necessary changes. This process is called reconciliation. By using the virtual DOM, React minimizes direct manipulation of the real DOM, which can be slow and inefficient.


What is virtual DOM in React?

Introduction

The virtual DOM is a concept implemented by libraries like React to improve the performance of web applications. It is a programming concept where a virtual representation of the UI is kept in memory and synced with the real DOM by a library such as ReactDOM.

How it works

  1. Initial rendering: When a React component is rendered for the first time, a virtual DOM tree is created. This tree is a lightweight copy of the actual DOM.
  2. Updating state: When the state of a component changes, a new virtual DOM tree is created. React then compares this new tree with the previous one.
  3. Diffing algorithm: React uses a diffing algorithm to find the differences between the new virtual DOM tree and the previous one. This process is called reconciliation.
  4. Updating the real DOM: After identifying the differences, React updates only the parts of the real DOM that have changed, rather than re-rendering the entire UI.

Benefits

  • Performance: By minimizing direct manipulation of the real DOM, React can update the UI more efficiently.
  • Abstraction: Developers can write code without worrying about the performance implications of direct DOM manipulation.
  • Predictability: The virtual DOM provides a predictable way to update the UI, making it easier to reason about the state of the application.

Example

Here is a simple example to illustrate how the virtual DOM works in React:

import React, { useState } from 'react';
function Counter() {
const [count, setCount] = useState(0);
return (
<div>
<p>You clicked {count} times</p>
<button onClick={() => setCount(count + 1)}>Click me</button>
</div>
);
}
export default Counter;

In this example, when the button is clicked, the state count is updated. React creates a new virtual DOM tree, compares it with the previous one, and updates only the text inside the <p> tag in the real DOM.

Further reading

在GitHub上编辑