Lädt...

🔧 Design Pattern #6 - Composite Pattern


Nachrichtenbereich: 🔧 Programmierung
🔗 Quelle: dev.to

In today’s article, which is part of our series about frontend design patterns, I will explain the Composite Pattern, explore real-world examples, and provide a hands-on JavaScript implementation. Let's dive in!

Composite Pattern is a structural design pattern that organizes objects into tree structures for representing whole-part hierarchies. It helps you handle individual objects and groups of objects in the same way. This pattern is handy for working with tree-like structures, like user interfaces or organizational hierarchies.

In JavaScript, the Composite Pattern can be implemented by creating a base component class that defines the common interface for both simple and composite objects. “Leaf” objects represent the end objects in the composition, while composite objects can contain other leaf or composite objects.

Real case scenario

A common challenge developers face is managing a complex UI with nested elements, such as menus with submenus or file systems with directories and files. Without a structured approach, the code can become difficult to manage and extend, leading to potential bugs and inefficiencies.

This is where the Composite Pattern comes into play. By treating individual UI elements and groups of elements uniformly, developers can simplify the management of nested components. For instance, consider a menu system where we have two types of components: MenuItem and Menu. MenuItem represents a single menu item, while Menu can contain multiple MenuItem objects and other Menu objects. Both MenuItem and Menu implement a common interface, allowing the main menu to treat them uniformly. This pattern not only makes the code more manageable but also enhances its extensibility.

Hands-on

To better understand the Composite Pattern, let's implement a simple example using JavaScript.

// Component interface
class MenuComponent {
  add(component) {}
  remove(component) {}
  getChild(index) {}
  display() {}
}

// Leaf object
class MenuItem extends MenuComponent {
  constructor(name) {
    super();
    this.name = name;
  }

  display() {
    console.log(this.name);
  }
}

// Composite object
class Menu extends MenuComponent {
  constructor(name) {
    super();
    this.name = name;
    this.children = [];
  }

  add(component) {
    this.children.push(component);
  }

  remove(component) {
    this.children = this.children.filter(child => child !== component);
  }

  getChild(index) {
    return this.children[index];
  }

  display() {
    console.log(this.name);
    this.children.forEach(child => child.display());
  }
}

// Client code
const mainMenu = new Menu('Main Menu');
const menuItem1 = new MenuItem('Item 1');
const menuItem2 = new MenuItem('Item 2');
const subMenu = new Menu('Sub Menu');
const subMenuItem1 = new MenuItem('Sub Item 1');

mainMenu.add(menuItem1);
mainMenu.add(menuItem2);
mainMenu.add(subMenu);
subMenu.add(subMenuItem1);

// Display the menu structure
mainMenu.display();

Let's break down the code:

MenuComponent: This is the base class, serving as an interface for both leaf and composite objects. It defines the common methods like add, remove, getChild, and display.

MenuItem: This class represents the leaf objects in the composite pattern. It extends MenuComponent and implements the display method to output its name.

Menu: This class represents composite objects that can contain children (both MenuItem and other Menu objects). It extends MenuComponent and implements methods to add, remove, retrieve, and display its children.

Client code: The example creates a menu structure with a main menu, menu items, and a sub-menu. It then adds items to the main menu and the sub-menu, and finally displays the entire structure.

Conclusion

By applying the Composite Pattern, you can manage complex UI components efficiently, handle organizational hierarchies, and structure data representations such as file systems. This pattern makes your codebase more maintainable and scalable, particularly in scenarios where you need to treat individual objects and compositions of objects uniformly.

If you have any questions feel free to drop a comment below. Also, make sure to check out the other articles in our frontend design patterns series!

Stay tuned for our next post coming next week!

Super Invitation - Win $5.000

So, while you are here, let me invite you to participate in our upcoming Superthis August!

From Aug 9-31, you'll be challenge to transform your virtual interactions with SuperViz’s real-time communication and data synchronization platform and a chance to win a prize of $5,000.

Register now to receive updates, tips and resources and get ready to hack!

...

🔧 Module-Pattern | Javascript Design Pattern Simplified | Part 4


📈 21.54 Punkte
🔧 Programmierung

🔧 Decorator-Pattern | Javascript Design Pattern Simplified | Part 5


📈 21.54 Punkte
🔧 Programmierung

🔧 Factory-Pattern | Javascript Design Pattern Simplified | Part 2


📈 21.54 Punkte
🔧 Programmierung

🔧 Observer-Pattern | Javascript Design Pattern Simplified | Part 3


📈 21.54 Punkte
🔧 Programmierung

🔧 Singleton-Pattern | Javascript Design Pattern Simplified | Part 1


📈 21.54 Punkte
🔧 Programmierung

🔧 Design Pattern #4 - Publisher/Subscriber Pattern


📈 21.54 Punkte
🔧 Programmierung

🔧 Design Pattern #3 - Observer Pattern


📈 21.54 Punkte
🔧 Programmierung

🔧 Design Pattern #2 - Facade Pattern


📈 21.54 Punkte
🔧 Programmierung

🐧 Observer Pattern: Was steckt hinter dem Observer Design Pattern?


📈 21.54 Punkte
🐧 Server

🔧 🏢 Architecture Style vs. Architecture Pattern vs. Design Pattern


📈 21.54 Punkte
🔧 Programmierung

🔧 [Design Pattern] Observer pattern for achievement System


📈 21.54 Punkte
🔧 Programmierung

🔧 Implementing Chain of Responsibility Pattern in C# : Middleware's Design Pattern


📈 21.54 Punkte
🔧 Programmierung

🔧 Design Pattern #7 - Builder Pattern


📈 21.54 Punkte
🔧 Programmierung

🔧 Design Pattern #5 - Adapter Pattern


📈 21.54 Punkte
🔧 Programmierung

🔧 Recognizing Design Patterns in System Design - Facade pattern and AWS API Gateway


📈 18.27 Punkte
🔧 Programmierung

🔧 Observer Design Pattern | Low Level Design


📈 18.27 Punkte
🔧 Programmierung

🔧 Learn Design Patterns: Mastering the Singleton Design Pattern


📈 18.27 Punkte
🔧 Programmierung

🔧 Learn Design Patterns: Unlocking the Power of the Prototype Design Pattern


📈 18.27 Punkte
🔧 Programmierung

🔧 Inversion of Control (Design Principle) & Dependency Injection (Design Pattern)


📈 18.27 Punkte
🔧 Programmierung

🔧 A transição do Higher-Order Component pattern para o React Hooks pattern


📈 16.54 Punkte
🔧 Programmierung

📰 Neu in .NET 7 [5]: List Pattern und Slice Pattern mit C# 11


📈 16.54 Punkte
📰 IT Nachrichten

🔧 C# Pattern Matching Inside Out: Kompakter und prägnanter C#-Code durch Pattern Matching


📈 16.54 Punkte
🔧 Programmierung

🐧 Factory Pattern: Alle Informationen zum Factory Method Pattern


📈 16.54 Punkte
🐧 Server

⚠️ [dos] Pdfium - Out-of-Bounds Read with Shading Pattern Backed by Pattern Colorspace


📈 16.54 Punkte
⚠️ PoC

🔧 forloop-pattern for num 1 2 3 4 5 6 7 8 9 & star pattern


📈 16.54 Punkte
🔧 Programmierung

🔧 Builder Pattern-Pattern


📈 16.54 Punkte
🔧 Programmierung

🔧 @Slf4j = Facade Pattern + Service Locator Pattern


📈 16.54 Punkte
🔧 Programmierung

🔧 Webkul pattern question advance pattern for interview with python


📈 16.54 Punkte
🔧 Programmierung

🔧 Service: O pattern que virou anti-pattern


📈 16.54 Punkte
🔧 Programmierung

🔧 Pub/Sub pattern vs Observer Pattern: what's the difference?


📈 16.54 Punkte
🔧 Programmierung

🔧 Go program pattern 01: Functional Options Pattern


📈 16.54 Punkte
🔧 Programmierung

🔧 Getting Started with Object-Oriented Design (Part 2): Design Principles and Design Patterns


📈 14.99 Punkte
🔧 Programmierung

🔧 System design | High Level Design and Low Level Design | Part 2


📈 14.99 Punkte
🔧 Programmierung

matomo