Frontend Development: DOM vs Shadow DOM vs Virtual DOM

Peter Jeon·2023년 6월 24일
0

Frontend Development

목록 보기
27/80

DOM vs Shadow DOM vs Virtual DOM

In this blog, we will be discussing three key concepts in frontend development: DOM, Shadow DOM, and Virtual DOM.

DOM (Document Object Model)

DOM

The DOM is a programming interface for web documents. It represents the structure of a web document in a tree-like format, where each node in the tree ends up being a part of the web page.

// Example of DOM manipulation
let element = document.getElementById('myElement');
element.innerHTML = 'Hello, World!';

Shadow DOM

Shadow DOM

The Shadow DOM is a web standard that helps you build components. It provides encapsulation by hiding DOM behind your component.

// Example of Shadow DOM
let shadow = this.attachShadow({mode: 'open'});
let childElement = document.createElement('p');
childElement.textContent = 'Hello, Shadow DOM!';
shadow.appendChild(childElement);

Virtual DOM

The Virtual DOM is a concept implemented by libraries such as React to improve performance by minimizing direct manipulation of the DOM.

// Example of Virtual DOM in React
const element = <h1>Hello, Virtual DOM!</h1>;
ReactDOM.render(element, document.getElementById('root'));

Comparison

DOMShadow DOMVirtual DOM
DefinitionProgramming interface for web documentsEncapsulates DOM behind componentsConcept to improve performance
Use CaseBasic web page manipulationComponent-based web developmentLarge scale web applications

Conclusion

In conclusion, DOM, Shadow DOM, and Virtual DOM are all vital parts of modern frontend development. While the DOM is the foundation, Shadow DOM provides encapsulation for reusable components, and Virtual DOM offers performance optimization for large scale applications. Understanding these concepts is crucial for any frontend developer.

profile
As a growing developer, I am continually expanding my skillset and knowledge, embracing new challenges and technologies

0개의 댓글