Skip to main content

Demystifying React ’s Virtual DOM


React has become one of the most popular Javascript UI libraries and today we are going to see one of the most important reasons behind it — its efficiency in updating the DOM. That’s where React ’s Virtual DOM comes into play.
What is Virtual DOM?
Virtual DOM is in-memory representation of the Real DOM. It is a lightweight JavaScript object which is a copy of the Real DOM. If it’s a copy of the real DOM, why do we say it makes the update faster? For that we first see…
Why is real DOM update slow? Or is it really?
Updating real DOM is not slow.Its merely updating a javascript object. Let’s now look at what actually makes the update process slower.


Rendering engine which is responsible for displaying or rendering the web page on the browser screen parses the HTML page to create the DOM. It also parses the CSS and applies the CSS to the HTML creating a render tree, this process is called as attachment.
Layout process give exact coordinates to each node of the render tree, where the node gets painted and displayed.
So when we do,
document.querySelector('#elementId').innerHTML="New Value"
Following thing happens:
  1. Browser has to parse the HTML.
  2. It removes the child element of ‘elementId’
  3. Updates the DOM with the “New Value”
  4. Re-calculates the CSS for the parent and child
  5. Updates the layout i.e. each element’s exact coordinates on the screen
  6. Traverses the render tree and paints it on the browser display
Recalculating the CSS and changed layouts uses complex algorithm and they affect the performance. Thus updating the DOM is not just updating the DOM but many more things as seen above.
How virtual DOM solves this problem:
  1. Efficient diffing algorithm
  2. Batched update operations
  3. Efficient update of subtree only
  4. Observable instead of dirty checking
But before going into any of the above let’s try to understand the concept of virtual DOM and the update of real DOM more clearly.
As already mentioned virtual DOM like the real DOM is too a simple js object.React always maintains two virtual DOMs one with the initial state and the other with the updated state of UI. And further the real DOM is updated based on the changes in the two. For this comparison React uses the diffing algorithm instead of state of the art algorithms .
Lets see why and how.
The Diffing Algorithm:
It is required to compare between two virtual DOMs as generated by the render() method .So for example if we use the state of the arts algorithm [O(n³)] it would take 1000 comparisons to display 10 elements.There comes the diffing Algorithm of the order O(n) which involves a heuristic approach to achieve the same:
  1. Two elements of different types will produce different trees.
  2. The developer can hint at which child elements may be stable across different renders with a key prop.
Some key aspects of the Diffing algorithm:
  1. When the comparison is in between two elements of different types:
<div>
   <Counter />
</div>

<span>
  <Counter />
</span>
When diffing above two the initial div tree is teared down and removed completely from the DOM and the span gets mounted.
2. When the comparison is in between two elements of same types:
<div>
   <Counter />
</div>
  <div>
   <Voucher />
</div>
Only the child element gets updated and similarly in
<div style={{color: 'red', fontWeight: 'bold'}} />

<div style={{color: 'green', fontWeight: 'bold'}} />
Only the color property gets updated.
Appending more children:
<ul>
  <li>Duke</li>
  <li>Villanova</li>
</ul>

<ul>
  <li>Connecticut</li>
  <li>Duke</li>
  <li>Villanova</li>
</ul>
Here, only the new child is added and the rest involves only the move operation for update. The life saver Keys prop. React suggests using keys attribute with the children especially with iterators and arrays to avoid unnecessary comparisons:
<ul>
  <li key="2015">Duke</li>
  <li key="2016">Villanova</li>
</ul>

<ul>
  <li key="2014">Connecticut</li>
  <li key="2015">Duke</li>
  <li key="2016">Villanova</li>
</ul>
Now React knows that the element with key ‘2014’ is the new one, and the elements with the keys ‘2015’ and ‘2016’ have just moved. This is how React js most efficiently uses the Diffing Algorithm to make it so efficient.
Updating the subtree only:
ReactJS traverses the tree using BST. Consider the tree below. States of element B and H have changed. So when using BST ReactJS reached element B it will by default re-render the element H. This is the reason to use BST for tree traversal.


Batch Update operations:
React using the diffing algorithm executes all the updates in one event loop thus causing the real DOM to update only once. If any further updates take place in the state they wait till the event loop gets over.
The Conclusion:
So this is how efficiently React uses the virtual DOM and the diffing algorithm that makes it much more efficient and faster than other js libraries like Angular a.
Written by : Divy Khare
Source : Demystifying React ’s Virtual DOM – Nybles – Medium

Comments

Popular posts from this blog

What is Blockchain Technology?

A  Blockchain , initially  Block chain , is a developing rundown of records called blocks, which are connected utilizing cryptography. Blockchains which are decipherable by people in general are broadly utilized by cryptocurencies. Private blockchains have been proposed for business utilize. Here, is a short story which will make you comfortable with the  Blockchain Technology . Mario and Luigi Mario needs to send $100 to his brother, Luigi, because Luigi being Luigi, he got into some debts at the other end of the world. Mario walks into the bank and says “I’d like to send $100 to Luigi”. The Cashier says “Account card please”, “ID please”, ”signature” and “done”. In this centralized situation, the bank is the *central* expert over Mario's and Luigi's cash. Both Mario and Luigi trust the bank to exchange the sum, and trust the numbers appeared on their bank account statements. They trust the bank in-spite of the way that all the bank needs to do is c...

Android Livedata and MutableLiveData

Open Event Android   Android Livedata and MutableLiveData December 14, 2018 Problem Suppose that we need to perform actions in light of changes in lifecycle status of Android Component. Some of the time you may wanna observe certain qualities being changed over the setup change. We all faced these problems somewhere down the road, trying a lot of different patterns MVP, MVVM, and others. But to implement these patterns is also a big problem for beginners. Solution The good news is that with the Android Architecture Component and more precisely with the lifecycle LiveData and ViewModel , we can easily overcome these problems. LiveData LiveData is an observable data holder. It is also a lifecycle aware. By lifecycle aware I mean, it can only be observed in the context of a lifecycle, more precisely in the context of an Activity or Fragment lifecycle. By passing the reference of an Activity or Fragment , it can understand whe...

Why use Snackbar instead of Toasts?

Open Event Android   Why use Snackbar instead of Toasts? January 14, 2019 Problem Toasts are kind of deprecated as any user who has disabled notifications for an app won't be able to see toast as well. The Open Event Android App was using toast for displaying information. So the task is to completely remove toasts and use snackbar instead. Solution Why Snackbar? Snackbars provide lightweight feedback about an operation. They show a brief message at the bottom of the screen on mobile and lower left on larger devices. Snackbars appear above all other elements on screen and only one can be displayed at a time.They automatically disappear after a timeout or after user interaction elsewhere on the screen, particularly after interactions that summon a new surface or activity. Snackbars can be swiped off screen. The Difference Snackbar Contain a single line of text directly related to the operation performed. They may contain a text action,...