Virtual DOM explained

A virtual DOM is a lightweight JavaScript representation of the Document Object Model (DOM) used in declarative web frameworks such as React, Vue.js, and Elm.[1] Since generating a virtual DOM is relatively fast, any given framework is free to rerender the virtual DOM as many times as needed relatively cheaply. The framework can then find the differences between the previous virtual DOM and the current one (diffing), and only makes the necessary changes to the actual DOM (reconciliation).[2] [3] While technically slower than using just vanilla JavaScript, the pattern makes it much easier to write websites with a lot of dynamic content, since markup is directly coupled with state.

Similar techniques include Ember.js' Glimmer and Angular's incremental DOM.[4]

History

The JavaScript DOM API has historically been inconsistent across browsers, clunky to use, and difficult to scale for large projects. While libraries like jQuery aimed to improve the overall consistency and ergonomics of interacting with HTML,[5] it too was prone to repetitive code that didn't describe the nature of the changes being made well and decoupled logic from markup.

The release of AngularJS in 2010 provided a major paradigm shift in the interaction between JavaScript and HTML with the idea of dirty checking.[6] Instead of imperatively declaring and destroying event listeners and modifying individual DOM nodes, changes in variables were tracked and sections of the DOM were invalidated and rerendered when a variable in their scope changed. This digest cycle provided a framework to write more declarative code that coupled logic and markup in a more logical way.

While AngularJS aimed to provide a more declarative experience, it still required data to be explicitly bound to and watched by the DOM, and performance concerns were cited over the expensive process of dirty checking hundreds of variables.[7] To alleviate these issues, React was the first major library to adopt a virtual DOM in 2013, which removed both the performance bottlenecks (since diffing and reconciling the DOM was relatively cheap) and the difficulty of binding data (since components were effectively just objects).[8] Other benefits of a virtual DOM included improved security since XSS was effectively impossible and better extensibility since a component's state was entirely encapsulated.[9] Its release also came with the advent of JSX, which further coupled HTML and JavaScript with an XML-like syntax extension.

Following React's success, many other web frameworks copied the general idea of an ideal DOM representation in memory, such as Vue.js in 2014, which used a template compiler instead of JSX and had fine-grained reactivity built as part of the framework.[10]

In recent times, the virtual DOM has been criticized for being slow due to the additional time required for diffing and reconciling DOM nodes.[11] This has led to the development of frameworks without a virtual DOM, such as Svelte, and frameworks that edit the DOM in-place such as Angular 2.

Implementations

React

React pioneered the use of a virtual DOM to make components declaratively. Virtual DOM nodes are constructed using the createElement function, but are often transpiled from JSX to make writing components more ergonomic.[12] In class-based React, virtual DOM nodes are returned from the render function, while in functional hook-based components, the return value of the function itself serves as the page markup.

Vue.js

Vue.js uses a virtual DOM to handle state changes, but is usually not directly interacted with; instead, a compiler is used to transform HTML templates into virtual DOM nodes as an implementation detail.[13] While Vue supports writing JSX and custom render functions,[14] it's more typical to use the template compiler since a build step isn't required that way.

Svelte

Svelte does not have a virtual DOM, with its creator Rich Harris calling the virtual DOM "pure overhead".[15] Instead of diffing and reconciling DOM nodes at runtime, Svelte uses compile-time reactivity to analyze markup and generate JavaScript code that directly edits the HTML, drastically increasing performance.[16]

See also

Notes and References

  1. Web site: Beginning Elm. 2020-12-11. Elm Programming.
  2. Web site: Virtual DOM and Internals – React. 2020-12-11. reactjs.org. en.
  3. Web site: React: The Virtual DOM. 2020-12-11. Codecademy. en.
  4. Web site: React Virtual DOM vs Incremental DOM vs Ember's Glimmer: Fight. 2020-12-11. Auth0 - Blog. en.
  5. Web site: openjsf.org . OpenJS Foundation- . The jQuery Object jQuery Learning Center . 2024-11-11 . en-US.
  6. Web site: 2014-01-30 . Make Your Own AngularJS, Part 1: Scopes And Digest . 2024-11-11 . 2014-01-30 . https://web.archive.org/web/20140130084907/http://teropa.info/blog/2013/11/03/make-your-own-angular-part-1-scopes-and-digest.html . bot: unknown .
  7. Web site: Utley . Tatum . The death of AngularJS and why you should care . 2024-11-11 . blog.core10.io . en.
  8. Pete Hunt: React: Rethinking best practices -- JSConf EU . 2013-10-30 . JSConf . 2024-11-11 . YouTube.
  9. Web site: Why did we build React? – React Blog . 2024-11-11 . legacy.reactjs.org . en.
  10. Web site: Reactivity in Depth — Vue.js . 2024-11-11 . v2.vuejs.org . en.
  11. Web site: Harris . Rich . 2018-12-27 . Virtual DOM is pure overhead . 2024-11-11 . svelte.dev . en.
  12. Web site: Writing Markup with JSX – React . 2024-11-11 . react.dev . en.
  13. Web site: Rendering Mechanism . Vue.js.
  14. Web site: Render Functions & JSX . Vue.js.
  15. Web site: Dec 27 2018 . Rich Harris Thu . 27 December 2018 . Virtual DOM is pure overhead . 2020-12-11 . svelte.dev . en.
  16. Web site: Harris . Rich . 2019-04-22 . Svelte 3: Rethinking reactivity . 2024-11-11 . svelte.dev . en.