„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Beherrschung zusammengesetzter Komponenten: Aufbau flexibler und wiederverwendbarer Reaktionskomponenten

Beherrschung zusammengesetzter Komponenten: Aufbau flexibler und wiederverwendbarer Reaktionskomponenten

Veröffentlicht am 17.11.2024
Durchsuche:870

Einführung

Etwas, das in der Welt von React sehr nützlich und umfassend ist, sind seine Entwurfsmuster, da sie dazu beitragen, den Code skalierbar zu halten und den von uns erstellten Komponenten Bedeutung zu verleihen.

Es gibt mehrere Muster, und in diesem Artikel werden wir über zusammengesetzte Komponenten sprechen, ein erweitertes Muster, das besonders nützlich für die Erstellung flexibler, zusammengesetzter Schnittstellen ist.

Was sind zusammengesetzte Komponenten?

Compound Components ist ein erweitertes Muster in React. Ziel ist es, ein flexibleres Design zu schaffen, das die gemeinsame Nutzung von Status und Logik zwischen einer Gruppe von Komponenten ermöglicht, wobei die Kommunikation zwischen der übergeordneten Komponente und den untergeordneten Komponenten auf flexible Weise erfolgen muss.

Komponenten müssen zusammenarbeiten, um ein bestimmtes Verhalten auszuführen, ohne peinliche Requisitenbäume oder Logik zu erzeugen, die zu komplex ist, um in Zukunft umgestaltet oder verstanden zu werden.

Dieses Muster hilft uns, Prop-Flaming zu vermeiden, bei dem wir einen Prop-Baum zwischen Komponenten übergeben müssen. Diese Requisiteninjektion ist ein Problem, da sie bei jedem aktualisierten Status zu mehreren unnötigen erneuten Renderings führen kann, da jeder Status alle untergeordneten Komponenten aktualisiert.

Wir haben ein Beispiel für zusammengesetzte Komponenten in der Struktur von Select- und Option-Tags in HTML:

Dominando Compound Components: Construindo Componentes React Flexíveis e Reutilizáveis

Die Auswahl fungiert als Schnittstellenstatusmanager, während die Optionen so konfiguriert werden, wie die Auswahl funktionieren soll.

Beispiel für die Verwendung zusammengesetzter Komponenten

In diesem Beispiel erstellen wir ein Modal, das in zwei zusammengesetzte Komponenten unterteilt ist: Toggle und Content. Wo sie den Zustand des Öffnens und Schließens des Modals untereinander teilen.

Sehen wir uns an, wie es wäre, diese Komponente Schritt für Schritt zu erstellen:

Wir können damit beginnen, den Kontext zu erstellen, der für die Verwaltung des Status des Öffnens und Schließens des Modals verantwortlich ist

Dominando Compound Components: Construindo Componentes React Flexíveis e Reutilizáveis

Erstellen der Basis der Modal-Komponente

Dominando Compound Components: Construindo Componentes React Flexíveis e Reutilizáveis

Beachten Sie, dass wir untergeordnete Elemente verwenden. Um die Komponenten zu erhalten, die in das Modal eingefügt werden, möchten wir es wie folgt verwenden:

Dominando Compound Components: Construindo Componentes React Flexíveis e Reutilizáveis

Jetzt müssen wir die Toggle-Komponente erstellen, die für das Öffnen des Modal verantwortlich ist

Dominando Compound Components: Construindo Componentes React Flexíveis e Reutilizáveis

Wir benötigen außerdem die Inhaltskomponente, die für die Anzeige des Inhalts des Modals verantwortlich ist

Dominando Compound Components: Construindo Componentes React Flexíveis e Reutilizáveis

Schließlich können wir beides unserer Modal-Komponente zuweisen und das war's (:

Dominando Compound Components: Construindo Componentes React Flexíveis e Reutilizáveis

Verwenden

Dominando Compound Components: Construindo Componentes React Flexíveis e Reutilizáveis

Ergebnis

Dominando Compound Components: Construindo Componentes React Flexíveis e Reutilizáveis

Auf diese Weise machen wir die Erstellung und Verwendung von Modalen äußerst flexibel und wiederverwendbar. Modal.Toggle ist für die Aktivierung der modalen Anzeige verantwortlich, während Modal.Content den Inhalt unseres Modals anzeigen muss.

Dieses Framework ermöglicht es Entwicklern, das Verhalten und den Inhalt von Modalen einfach an die spezifischen Anforderungen ihrer Anwendungen anzupassen, wodurch der Code sauberer und organisierter wird.

Andere Beispiele

Wir können zusammengesetzte Komponenten auch in anderen Kontexten verwenden, zum Beispiel:

Akkordeonkomponenten:

Dominando Compound Components: Construindo Componentes React Flexíveis e Reutilizáveis

Menükomponenten:

Dominando Compound Components: Construindo Componentes React Flexíveis e Reutilizáveis

Alle sind flexibel und anpassungsfähig und erleichtern die Entwicklung, Skalierbarkeit und Verwendung der Komponente.

Abschluss

Wir haben gesehen, wie nützlich das Schreiben von Komponenten im Compound Components-Muster in unseren Anwendungen sein kann, wir haben auch gesehen, wie man es verwendet und einige Beispiele, wo dieses Muster passen kann.

Fühlen Sie sich frei, die Erstellung von Komponenten mit Compoud Components zu erforschen und herumzuprobieren, verwenden Sie es mit Bedacht und prüfen Sie, ob es wirklich Sinn macht, es in Ihrem Kontext anzuwenden. Manchmal kann es, wenn es nicht gut angewendet wird, eher ein Hindernis sein als eine Hilfe.

HINWEIS: Ich habe denselben Inhalt auf React4noobs gepostet, einem Repository zum Gruppieren von Artikeln, die von Entwicklern im React-Universum erstellt wurden. Es lohnt sich, einen Blick darauf zu werfen =).

Freigabeerklärung Dieser Artikel ist abgedruckt unter: https://dev.to/gabrielduete/dominando-compound-components-construindo-componentes-react-flexiveis-e-reutilizaveis-30e?1 Bei Verstößen wenden Sie sich bitte an [email protected] um es zu löschen
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3