Heim >Web-Frontend >js-Tutorial >Spickzettel zur Reagieren-Memorisierung

Spickzettel zur Reagieren-Memorisierung

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-11-06 02:28:02614Durchsuche

React Memoization Cheat Sheet

React bietet drei Haupttools für die Memoisierung, um die Komponentenleistung zu optimieren, indem unnötige erneute Renderings und Neuberechnungen minimiert werden:

1. useMemo – Berechnete Werte merken

  • Zweck: Speichert das Ergebnis einer Berechnung zwischen und berechnet es nur neu, wenn sich Abhängigkeiten ändern.
  • Verwendung: Verwendung für kostspielige Berechnungen oder abgeleitete Daten, die nur bei bestimmten Abhängigkeiten aktualisiert werden sollten.

    const memoizedValue = useMemo(() => complexCalculation(), [dependencies]);
    
    
  • Best Practices:

    • Fügen Sie alle innerhalb der Funktion verwendeten Abhängigkeiten in das Abhängigkeitsarray ein.
    • Vermeiden Sie das Erstellen neuer Referenzen (Arrays, Objekte) oder Inline-Funktionen in useMemo.
    • Hinweis: Verwenden Sie useMemo nicht für Funktionen; Es speichert Werte zwischen, keine Funktionsreferenzen.

2. useCallback – Funktionsreferenzen auswendig lernen

  • Zweck: Speichert eine Funktionsreferenz im Cache und verhindert so eine Neuerstellung bei jedem Rendern.
  • Verwendung: Verwendung für stabile Funktionsreferenzen, insbesondere für Rückrufe (z. B. Event-Handler), die an untergeordnete Komponenten übergeben werden.

    const memoizedFunction = useCallback(() => { /* logic */ }, [dependencies]);
    
    
  • Best Practices:

    • Fügen Sie alle innerhalb der Funktion verwendeten Abhängigkeiten in das Abhängigkeitsarray ein, um veraltete Werte zu vermeiden.
    • Vermeiden Sie die Deklaration von Inline-Funktionen innerhalb von useCallback, da dies die Memoisierung unterbrechen kann.
    • Hinweis: Verwenden Sie useCallback nur für Funktionen. Der Missbrauch von useCallback für Werte führt zu ineffizientem Code mit unnötigen Funktionsaufrufen.

3. React.memo – Ganze Komponenten auswendig lernen

  • Zweck: Verhindert, dass eine Funktionskomponente erneut gerendert wird, wenn sich ihre Requisiten nicht geändert haben.
  • Verwendung: Zur Optimierung untergeordneter Komponenten, die nicht erneut gerendert werden müssen, wenn sich die übergeordnete Komponente ändert.

    const MemoizedComponent = React.memo(ChildComponent);
    
    
  • Best Practices:

    • Verwendung bei Komponenten, die stabile Stützen oder Stützen erhalten, die sich selten ändern.
    • Vermeiden Sie häufige Änderungen an Requisiten (wie neue Objekte/Arrays), um die Effektivität von React.memo zu maximieren.
    • Hinweis: Funktioniert gut mit useCallbackmemoized-Funktionen, um stabile Requisiten aufrechtzuerhalten, die an untergeordnete Komponenten übergeben werden.

Wichtige Punkte, die Sie sich merken sollten

  • Verwenden Sie useMemo für Werte und useCallback für Funktionen.
    • Die Verwendung von useMemo für Funktionen führt zu einer sofortigen Ausführung und nicht zu einer stabilen Funktionsreferenz.
    • Die Verwendung von useCallback für Werte gibt eine Funktion zurück, was zu ineffizientem Code mit zusätzlichen Funktionsaufrufen führt.
  • Memoization-Zusammenfassung:
    • useMemo: Cachet berechnete Werte (Rückgabewerte von Funktionen).
    • useCallback: Zwischenspeichert Funktionsreferenzen (Callbacks).
    • React.memo: Zwischenspeichert gesamte Komponenten basierend auf Requisiten, um ein erneutes Rendern durch übergeordnete Aktualisierungen zu verhindern.
  • Selektive Verwendung von Memoisierung: Memoisierung verbessert die Leistung bei korrekter Verwendung, kann jedoch bei übermäßiger oder falscher Verwendung die Komplexität erhöhen.

Das obige ist der detaillierte Inhalt vonSpickzettel zur Reagieren-Memorisierung. 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