What is virtual dom in Vuejs?

devquora
devquora

Posted On: Jun 20, 2024

 

    1 Answer Written

  •  devquora
    Answered by Vimlesh

    Virtual DOM? You have probably heard about the term "virtual DOM", which Vue's rendering system is based upon. The virtual DOM (VDOM) is a programming concept where an ideal, or “virtual”, representation of a UI is kept in memory and synced with the “real” DOM. The concept was pioneered by React, and has been adapted in many other frameworks with different implementations, including Vue. Virtual DOM is more of a pattern than a specific technology, so there is no one canonical implementation. We can illustrate the idea using a simple example: js const vnode = { type: 'div', props: { id: 'hello' }, children: [ /* more vnodes */ ] } Here, vnode is a plain JavaScript object (a "virtual node") representing a

    element. It contains all the information that we need to create the actual element. It also contains more children vnodes, which makes it the root of a virtual DOM tree. A runtime renderer can walk a virtual DOM tree and construct a real DOM tree from it. This process is called mount. If we have two copies of virtual DOM trees, the renderer can also walk and compare the two trees, figuring out the differences, and apply those changes to the actual DOM. This process is called patch, also known as "diffing" or "reconciliation". The main benefit of virtual DOM is that it gives the developer the ability to programmatically create, inspect and compose desired UI structures in a declarative way, while leaving the direct DOM manipulation to the renderer.

Related Questions

Please Login or Register to leave a response.

Related Questions

Vue.js Interview Questions

What is Vue.js?

Vue.js is a progressive JavaScript framework that simplifies UI development. It offers reactive data binding, component-based architecture, and a flexible ecosystem. Vue's simplicity and versatility m..

Vue.js Interview Questions

List some features of Vue.js.

Vue.js offers templates for easy UI creation, reactive data binding, component-based architecture, built-in transitions for animations, and dynamic routing for single-page applications. These features..

Vue.js Interview Questions

Explain Life cycle of Vue Instance.

The Vue.js lifecycle includes stages like creation for initialization, mounting for DOM insertion, updating for reactivity, and destroying for cleanup. Each stage provides hooks to manage component be..