Front-end engineers or anyone who tried to play with popular frontend libraries/frameworks like React and Vue.js, should all have heard about the Virtual DOM. It seems to have become a standard for improving performance in front-end development. However, there is also a trend that claims to not use the Virtual DOM. In this article, we will take a look at the Virtual DOM approach and discuss if Virtual DOM is outdated?
data:image/s3,"s3://crabby-images/2e35f/2e35f0fa002543d3fd112e59fe0ee498c445a1a3" alt="The Dom title image" represents the web document as nodes and objects; that way, programming languages can interact with the page.
Therefore, with DOM, we can easily work on the HTML nodes to create interactive components on a web page with Javascript and CSS.
DOM Tree Example
data:image/s3,"s3://crabby-images/40258/40258ce08cbfce1be4874dd1149163b8fe4dd8fb" alt="DOM Tree Example" DOM Revolutions
The Concept
As described above, since it costs so much for operating the DOM directly, what about to create a gateway that can be friendly to developers, at the same time it can help to reduce the unnecessary loads and efficiently reflect changes on DOM at pin-point level? To solve this, here comes our main character, the Virtual DOM.
The Virtual DOM is an light-weight abstract layer between the real DOM and the developers. It is actually a set of Javascript Objects with only the necessary elements and attributes to represent DOM tree and the nodes under it. With this abstract DOM tree, it becomes much easier and faster to create, edit or remove nodes just like the any normal Javascript Object.
Furthermore, with Virtual DOM, the rendering process is also abstract, so that it provides more compatibility for Cross-platform, not only for web browsers, but also mobile native components or other GUI developments.
The Approach: diff & patch
Many people got to know Virtual DOM via React, but in fact Virtual DOM is not invented by React. Many other libraries/frameworks are taking Virtual DOM approach. There are also many projects that only focus on Virtual DOM implementation such as virtual-dom and millionjs.
Although the way they implement Virtual DOM differs, the main approach is quite similar. There are two essential steps: diff and patch.
data:image/s3,"s3://crabby-images/01f05/01f05c2175ffdc925af4e073bf40c0900de97780" alt="Virtual DOM Approach" {
var index = 0 // current node index
var patches = {} // record changes on each node
dfsWalk(oldTree, newTree, index, patches)
return patches
}
// depth-first walk through two DOM tree
function dfsWalk (oldNode, newNode, index, patches) {
// compare the changes and record by index
patches[index] = [...]
diffChildren(oldNode.children, newNode.children, index, patches)
}
// compare child nodes
function diffChildren (oldChildren, newChildren, index, patches) {
var leftNode = null
var currentNodeIndex = index
oldChildren.forEach(function (child, i) {
var newChild = newChildren[i]
currentNodeIndex = (leftNode && leftNode.count) // calculate node index
? currentNodeIndex + leftNode.count + 1
: currentNodeIndex + 1
dfsWalk(child, newChild, currentNodeIndex, patches) // traverse all child nodes
leftNode = child
})
}
Each Virtual DOM implementation may have its own algorithm to optimize the diff performance. Thanks to the efforts they have made, Virtual DOM became more and more mature, we don't even need to think about how it works during daily development.
Nevertheless, Virtual DOM is not the only solution for all.
data:image/s3,"s3://crabby-images/83af2/83af24e3d8a2e9a559e5e3e569e07315653ea65d" alt="The DOM Resurrections title image"
Dongyu Wang
Frontend Engineer