Heim > Web-Frontend > js-Tutorial > Verbessern Sie Ihre Reaktionsfähigkeiten: Hooks verstehen und verwenden

Verbessern Sie Ihre Reaktionsfähigkeiten: Hooks verstehen und verwenden

DDD
Freigeben: 2024-10-29 12:48:02
Original
996 Leute haben es durchsucht

Level Up Your React Skills: Understanding and Using Hooks

React-Hooks sind spezielle Funktionen, mit denen Sie React-Funktionen wie Status- und Lebenszyklusmethoden in Funktionskomponenten verwenden können. Sie wurden in React 16.8 eingeführt, um das Komponentenmodell zu vereinfachen und die gemeinsame Nutzung von Zustandslogik zwischen Komponenten zu erleichtern.

Hauptmerkmale von React Hooks:

Zustandsverwaltung: Mit Hooks wie useState können Sie den Zustand in Funktionskomponenten hinzufügen und verwalten, ohne diese in Klassenkomponenten konvertieren zu müssen.

Nebenwirkungen: Mit dem useEffect-Hook können Sie Nebenwirkungen wie Datenabruf, Abonnements oder manuelles Ändern des DOM ausführen, ähnlich wie bei Lebenszyklusmethoden in Klassenkomponenten.

Wiederverwendbarkeit: Mit benutzerdefinierten Hooks können Sie zustandsbehaftete Logik über verschiedene Komponenten hinweg kapseln und wiederverwenden.

Reinigercode: Haken helfen dabei, Komponenten sauber zu halten

Integrierte Haken

1 useState

  • Beschreibung: Ermöglicht das Hinzufügen von Status zu Funktionskomponenten.
  • Beispiel:
   import React, { useState } from 'react';

   const Counter = () => {
     const [count, setCount] = useState(0);
     return (
       <div>
         <p>Count: {count}</p>
         <button onClick={() => setCount(count + 1)}>Increment</button>
       </div>
     );
   };
Nach dem Login kopieren
Nach dem Login kopieren

2 useEffect

  • Beschreibung: Verwaltet Nebenwirkungen wie Datenabruf oder Abonnements in Funktionskomponenten.
  • Beispiel:
   import React, { useEffect, useState } from 'react';

   const DataFetcher = () => {
     const [data, setData] = useState(null);
     useEffect(() => {
       fetch('https://api.example.com/data')
         .then(response => response.json())
         .then(setData);
     }, []);
     return <div>{data ? JSON.stringify(data) : 'Loading...'}</div>;
   };
Nach dem Login kopieren
Nach dem Login kopieren

3 useContext

  • Beschreibung: Bietet Zugriff auf Kontextwerte, ohne dass ein Verbraucher erforderlich ist.
  • Beispiel:
   import React, { useContext } from 'react';

   const ThemeContext = React.createContext('light');

   const ThemedComponent = () => {
     const theme = useContext(ThemeContext);
     return <div className={`theme-${theme}`}>Current theme: {theme}</div>;
   };
Nach dem Login kopieren
Nach dem Login kopieren

4 useReducer

  • Beschreibung: Verwaltet komplexe Zustandslogik in Komponenten, ähnlich wie Redux.
  • Beispiel:
   import React, { useReducer } from 'react';

   const initialState = { count: 0 };
   const reducer = (state, action) => {
     switch (action.type) {
       case 'increment':
         return { count: state.count + 1 };
       case 'decrement':
         return { count: state.count - 1 };
       default:
         return state;
     }
   };

   const Counter = () => {
     const [state, dispatch] = useReducer(reducer, initialState);
     return (
       <div>
         <p>Count: {state.count}</p>
         <button onClick={() => dispatch({ type: 'increment' })}>Increment</button>
         <button onClick={() => dispatch({ type: 'decrement' })}>Decrement</button>
       </div>
     );
   };

Nach dem Login kopieren
Nach dem Login kopieren

5 useMemo

  • Beschreibung: Speichert einen berechneten Wert, um die Leistung zu optimieren und unnötige Neuberechnungen zu vermeiden.
  • Beispiel:
   import React, { useMemo, useState } from 'react';

   const ExpensiveComputation = ({ number }) => {
     const compute = (num) => {
       return num * 1000; // Simulate an expensive computation
     };
     const result = useMemo(() => compute(number), [number]);
     return <div>Computed Result: {result}</div>;
   };
Nach dem Login kopieren
Nach dem Login kopieren

6 useCallback

  • Beschreibung: Gibt eine gespeicherte Version einer Rückruffunktion zurück, die sich nur ändert, wenn sich eine der Abhängigkeiten geändert hat.
  • Beispiel:
   import React, { useCallback, useState } from 'react';

   const Button = React.memo(({ onClick, children }) => {
     console.log('Button rendered');
     return <button onClick={onClick}>{children}</button>;
   });

   const App = () => {
     const [count, setCount] = useState(0);
     const increment = useCallback(() => setCount(c => c + 1), []);
     return (
       <div>
         <p>Count: {count}</p>
         <Button onClick={increment}>Increment</Button>
       </div>
     );
   };
Nach dem Login kopieren
Nach dem Login kopieren

7 useRef

  • Beschreibung: Gibt ein veränderbares Referenzobjekt zurück, das für die gesamte Lebensdauer der Komponente bestehen bleibt und für den direkten Zugriff auf DOM-Elemente nützlich ist.
  • Beispiel:
   import React, { useRef } from 'react';

   const FocusInput = () => {
     const inputRef = useRef(null);
     const focusInput = () => {
       inputRef.current.focus();
     };
     return (
       <div>
         <input ref={inputRef} type="text" />
         <button onClick={focusInput}>Focus Input</button>
       </div>
     );
   };
Nach dem Login kopieren
Nach dem Login kopieren

8 useLayoutEffect

  • Beschreibung: Ähnlich wie useEffect, läuft jedoch synchron nach allen DOM-Mutationen und ermöglicht so die Messung des DOM-Layouts.
  • Beispiel:
   import React, { useLayoutEffect, useRef } from 'react';

   const LayoutEffectExample = () => {
     const divRef = useRef();
     useLayoutEffect(() => {
       console.log('Height:', divRef.current.clientHeight);
     }, []);
     return <div ref={divRef}>This is a div</div>;
   };
Nach dem Login kopieren
Nach dem Login kopieren

9 useImperativeHandle

  • Beschreibung: Passt den Instanzwert an, der verfügbar gemacht wird, wenn ref in übergeordneten Komponenten verwendet wird.
  • Beispiel:
   import React, { useState } from 'react';

   const Counter = () => {
     const [count, setCount] = useState(0);
     return (
       <div>
         <p>Count: {count}</p>
         <button onClick={() => setCount(count + 1)}>Increment</button>
       </div>
     );
   };
Nach dem Login kopieren
Nach dem Login kopieren

10 useDebugValue
- Beschreibung: Zeigt eine Beschriftung für benutzerdefinierte Hooks in React DevTools an, um das Debuggen zu erleichtern.
- Beispiel:

   import React, { useEffect, useState } from 'react';

   const DataFetcher = () => {
     const [data, setData] = useState(null);
     useEffect(() => {
       fetch('https://api.example.com/data')
         .then(response => response.json())
         .then(setData);
     }, []);
     return <div>{data ? JSON.stringify(data) : 'Loading...'}</div>;
   };
Nach dem Login kopieren
Nach dem Login kopieren

Benutzerdefinierte Haken

11 useFetch
- Beschreibung: Ein benutzerdefinierter Hook zum Abrufen von Daten von einer API.
- Beispiel:

   import React, { useContext } from 'react';

   const ThemeContext = React.createContext('light');

   const ThemedComponent = () => {
     const theme = useContext(ThemeContext);
     return <div className={`theme-${theme}`}>Current theme: {theme}</div>;
   };
Nach dem Login kopieren
Nach dem Login kopieren

12 LocalStorage verwenden
- Beschreibung: Synchronisiert den Status mit dem lokalen Speicher, um Daten über Sitzungen hinweg beizubehalten.
- Beispiel:

   import React, { useReducer } from 'react';

   const initialState = { count: 0 };
   const reducer = (state, action) => {
     switch (action.type) {
       case 'increment':
         return { count: state.count + 1 };
       case 'decrement':
         return { count: state.count - 1 };
       default:
         return state;
     }
   };

   const Counter = () => {
     const [state, dispatch] = useReducer(reducer, initialState);
     return (
       <div>
         <p>Count: {state.count}</p>
         <button onClick={() => dispatch({ type: 'increment' })}>Increment</button>
         <button onClick={() => dispatch({ type: 'decrement' })}>Decrement</button>
       </div>
     );
   };

Nach dem Login kopieren
Nach dem Login kopieren

13 usePrevious
- Beschreibung: Gibt den vorherigen Wert eines Zustands oder einer Eigenschaft zurück.
- Beispiel:

   import React, { useMemo, useState } from 'react';

   const ExpensiveComputation = ({ number }) => {
     const compute = (num) => {
       return num * 1000; // Simulate an expensive computation
     };
     const result = useMemo(() => compute(number), [number]);
     return <div>Computed Result: {result}</div>;
   };
Nach dem Login kopieren
Nach dem Login kopieren

14 useDebounce
- Beschreibung: Entprellt einen Wert oder Funktionsaufruf und verzögert die Ausführung bis nach einer angegebenen Verzögerung.
- Beispiel:

   import React, { useCallback, useState } from 'react';

   const Button = React.memo(({ onClick, children }) => {
     console.log('Button rendered');
     return <button onClick={onClick}>{children}</button>;
   });

   const App = () => {
     const [count, setCount] = useState(0);
     const increment = useCallback(() => setCount(c => c + 1), []);
     return (
       <div>
         <p>Count: {count}</p>
         <Button onClick={increment}>Increment</Button>
       </div>
     );
   };
Nach dem Login kopieren
Nach dem Login kopieren

15 useOnClickOutside
- Beschreibung: Erkennt Klicks außerhalb eines bestimmten Elements, nützlich zum Schließen von Popups oder Dropdowns.
- Beispiel:

   import React, { useRef } from 'react';

   const FocusInput = () => {
     const inputRef = useRef(null);
     const focusInput = () => {
       inputRef.current.focus();
     };
     return (
       <div>
         <input ref={inputRef} type="text" />
         <button onClick={focusInput}>Focus Input</button>
       </div>
     );
   };
Nach dem Login kopieren
Nach dem Login kopieren

16 useInterval
- Beschreibung: Richtet ein Intervall ein, um eine Funktion wiederholt in bestimmten Intervallen auszuführen.
- Beispiel:

   import React, { useLayoutEffect, useRef } from 'react';

   const LayoutEffectExample = () => {
     const divRef = useRef();
     useLayoutEffect(() => {
       console.log('Height:', divRef.current.clientHeight);
     }, []);
     return <div ref={divRef}>This is a div</div>;
   };
Nach dem Login kopieren
Nach dem Login kopieren

17 useTimeout
- Beschreibung: Richtet ein Timeout ein, um eine Funktion nach einer angegebenen Verzögerung auszuführen.
- Beispiel:

   import React, { useImperativeHandle, forwardRef, useRef } from 'react';

   const CustomInput = forwardRef((props, ref) => {
     const inputRef = useRef();
     useImperativeHandle(ref, () => ({
       focus: () => {
         inputRef.current.focus();
       }
     }));
     return <input ref={inputRef} type="text" />;
   });

   const Parent = () => {
     const ref = useRef();
     return (
       <div>
         <CustomInput ref={ref} />
         <button onClick={() => ref.current.focus()}>Focus Input</button>
       </div>
     );
   };
Nach dem Login kopieren

18 useMediaQuery
- Beschreibung:Überprüft, ob eine Medienabfrage übereinstimmt, was eine responsive Designlogik ermöglicht.
- Beispiel:

import { useDebugValue } from 'react';

    const useCustomHook = (value) => {
      useDebugValue(value ? 'Value is true' : 'Value is false');
      return value;
    };

    const DebugExample = () => {
      const isTrue = useCustomHook(true);
      return <div>Check the React DevTools</div>;
    };

Nach dem Login kopieren

19 useScrollPosition
- Beschreibung: Verfolgt die aktuelle Bildlaufposition des Fensters.
- Beispiel:

 import { useState, useEffect } from 'react';

    const useFetch = (url) => {
      const [data, setData] = useState(null);
      const [loading, setLoading] = useState(true);

      useEffect(() => {
        const fetchData = async () => {
          const response = await fetch(url);
          const result = await response.json();
          setData(result);
          setLoading(false);
        };
        fetchData();
      }, [url]);

      return { data, loading };
    };
Nach dem Login kopieren

20 useKeyPress
- Beschreibung: Erkennt, ob eine bestimmte Taste gedrückt wird.
- Beispiel:

import { useState, useEffect } from 'react';

    const useLocalStorage = (key, initialValue) => {
      const [storedValue, setStoredValue] = useState(() => {
        try {
          const item = window.localStorage.getItem(key);
          return item ? JSON.parse(item) : initialValue;
        } catch (error) {
          console.error(error);
          return initialValue;
        }
      });

      useEffect(() => {
        try {
          window.localStorage.setItem(key, JSON.stringify(storedValue));
        } catch (error) {
          console.error(error);
        }
      }, [key, storedValue]);

      return [storedValue, setStoredValue];
    };

Nach dem Login kopieren

Zusammenfassung

Diese Liste enthält jetzt Beschreibungen für jeden Hook, um ein klareres Verständnis ihrer Zwecke und Anwendungsfälle zu vermitteln. Wenn Sie weitere Details oder Beispiele benötigen, fragen Sie einfach nach!

Das obige ist der detaillierte Inhalt vonVerbessern Sie Ihre Reaktionsfähigkeiten: Hooks verstehen und verwenden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:dev.to
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage