Heim > Web-Frontend > js-Tutorial > ReactJS: Löst „setState' immer ein vollständiges erneutes Rendern aus?

ReactJS: Löst „setState' immer ein vollständiges erneutes Rendern aus?

Patricia Arquette
Freigeben: 2024-11-15 08:51:02
Original
667 Leute haben es durchsucht

ReactJS: Does `setState` Always Trigger a Full Re-render?

ReactJS: Wird „render“ jedes Mal ausgelöst, wenn „setState“ aufgerufen wird?

React ist darauf ausgelegt, Komponenten nur dann effizient neu zu rendern, wenn notwendig. Dieses Verhalten ist jedoch möglicherweise nicht immer offensichtlich, was zu Fragen zur Beziehung zwischen „setState“ und Rendering führt.

Standard-Rendering-Verhalten

Standardmäßig wird „setState“ aufgerufen „ löst ein vollständiges erneutes Rendern der Komponente und aller ihrer untergeordneten Komponenten aus. Dadurch wird sichergestellt, dass alle Statusänderungen genau in der Benutzeroberfläche widergespiegelt werden.

Dieses Verhalten ist darauf zurückzuführen, dass „shouldComponentUpdate“ standardmäßig immer „true“ zurückgibt. Diese Methode bestimmt, ob eine Komponente ihre Renderausgabe basierend auf Änderungen an Requisiten oder Status aktualisieren soll.

Zweck von Render

Auch wenn „render“ jedes Mal aufgerufen wird „ setState“ aufgerufen wird, aktualisiert React das DOM nicht sofort. Stattdessen wird ein virtuelles DOM generiert, das den gewünschten Zustand der Benutzeroberfläche darstellt. Das tatsächliche DOM wird nur geändert, wenn es Änderungen zwischen dem alten und dem neuen virtuellen DOM gibt.

Beispiel

Beachten Sie den in der Frage bereitgestellten Codeausschnitt:

this.setState({'test':'me'});
Nach dem Login kopieren

Obwohl sich der Status nach dem ersten Klick nicht ändert, werden sowohl die übergeordnete als auch die untergeordnete Komponente neu gerendert. Dies liegt daran, dass „shouldComponentUpdate“ immer true zurückgibt und ein erneutes Rendern erzwingt.

Optimierung des erneuten Renderns

Um unnötige erneute Renderings zu verhindern, können Sie „shouldComponentUpdate“ überschreiben " und vergleichen Sie die neuen Requisiten und den neuen Zustand mit den vorherigen Werten. Wenn es keine wesentlichen Änderungen gibt, die sich auf die Benutzeroberfläche auswirken würden, können Sie false zurückgeben, um das Rendern zu verhindern.

Bedenken Sie, dass die übermäßige Verwendung von „shouldComponentUpdate“ zu Leistungsproblemen führen kann, wenn die Logik zu komplex ist oder unnötige Vergleiche durchführt.

Das obige ist der detaillierte Inhalt vonReactJS: Löst „setState' immer ein vollständiges erneutes Rendern aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage