Heim >Web-Frontend >js-Tutorial >React.js: Status zwischen Komponenten teilen

React.js: Status zwischen Komponenten teilen

Patricia Arquette
Patricia ArquetteOriginal
2025-01-05 09:06:41433Durchsuche

Wenn dir meine Artikel gefallen, kannst du mir einen Kaffee kaufen oder ihn teilen :)
React.js : Sharing State Between Components


In diesem Artikel konzentrieren wir uns auf die Zustandsfreigabe zwischen Komponenten in unserem react.js.


Der Staat ist isoliert und privat

Wenn wir einen Zustand in einer Komponente erstellen, müssen wir zunächst verstehen, wie sich dieser Zustand verhält. Der innerhalb der Komponente erstellte Status ist lokal für die Komponente. Was bedeutet das also?

Wenn Sie dieselbe Komponente zweimal rendern, hat jede Kopie einen vollständig isolierten Zustand. Das Ändern einer davon hat keine Auswirkungen auf die andere. Das heißt, die Aktualisierung des Status einer der beiden Komponenten hat keine Auswirkungen auf die andere.

Lassen Sie es uns anhand eines Beispiels erklären.

React.js : Sharing State Between Components

Die gleiche Komponente wurde zweimal gerendert und auf die Schaltfläche geklickt. Das Ergebnis ist wie folgt.

Ausgabe:

React.js : Sharing State Between Components

Wie im GIF zu sehen ist, war jede Kopie vollständig isoliert und die Änderung einer davon hatte keinen Einfluss auf die andere.
Was wäre, wenn Sie möchten, dass die Zustände beider Komponenten synchron bleiben? Der richtige Weg, dies in React zu tun, besteht darin, den Status von untergeordneten Komponenten zu entfernen und ihn dem nächstgelegenen gemeinsamen übergeordneten Element hinzuzufügen.


Lassen Sie uns nun in drei Schritten die Zustände beider Komponenten synchron halten. Im Gegensatz zu Requisiten ist der Status vollständig spezifisch für die Komponente, die ihn deklariert. Um den Status zweier Komponenten zu synchronisieren, sollte ein gemeinsamer Status auf das nächste gemeinsame übergeordnete Element übertragen und als Requisiten an beide Komponenten weitergegeben werden.

Schritt 1: Entfernen Sie den Status von den untergeordneten Komponenten

Lassen Sie uns den isActive-Status auf die übergeordnete Komponente übertragen und isActive zur Prop-Liste des Panels hinzufügen. Jetzt kann die übergeordnete Komponente des Panels isActive steuern, indem sie es als prop weitergibt. Umgekehrt hat die Panel-Komponente jetzt keine Kontrolle über den Wert von isActive, es liegt nun an der übergeordneten Komponente.

React.js : Sharing State Between Components


Schritt 2: setIsActive Prop

Senden wir die Funktion, die den Status aktualisiert, als Requisite an die untergeordnete Komponente.

React.js : Sharing State Between Components


Schritt 3: onClick-Ereignis

Wenn das onClick-Ereignis der Schaltfläche ausgelöst wird, wird setIsActive ausgeführt und der Status aktualisiert.

React.js : Sharing State Between Components

Ausgabe :

React.js : Sharing State Between Components


Das Anheben des Zustands verändert oft die Art dessen, was Sie als Zustand speichern. In diesem Beispiel war es also in zwei Panels gleichzeitig aktiv. Wenn wir wollten, dass jeweils nur ein Panel aktiv ist? Das bedeutet, dass die allgemeine übergeordnete Komponente des Akkordeons verfolgen muss, welches Panel das aktive ist. Anstelle eines booleschen-Werts könnte eine Zahl als Index des aktiven Panels für die Statusvariable verwendet werden:

const [activeIndex, setActiveIndex] = useState(0);

Wenn der activeIndex 0 ist, ist das erste Panel aktiv, und wenn es 1 ist, ist es das zweite.

Durch Klicken auf die Schaltfläche „Anzeigen“ in einem der Panels muss der aktive Index in Accordion geändert werden. Ein Panel kann den Status activeIndex nicht direkt festlegen, da er im Akkordeon definiert ist. Die Accordion-Komponente muss der Panel-Komponente explizit erlauben, ihren Zustand zu ändern, indem sie einen Ereignishandler als prop:
weitergibt

 <Panel
    isActive={activeIndex === 0}
    onShow={() => setActiveIndex(0)}
  >
    ...
  </Panel>
  <Panel
    isActive={activeIndex === 1}
    onShow={() => setActiveIndex(1)}
  >
    ...
  </Panel>

Ausgabe:

React.js : Sharing State Between Components


Abschluss

Der innerhalb der Komponente erstellte Status ist lokal für die Komponente. In diesem Artikel haben wir untersucht, wie Status zwischen Komponenten geteilt wird. Wenn Sie möchten, können Sie in den Kommentaren über die Prinzipien der Zustandsfreigabe zwischen Komponenten sprechen.

Das obige ist der detaillierte Inhalt vonReact.js: Status zwischen Komponenten teilen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn