Maison > interface Web > js tutoriel > Niveau architecte : méthodes de cycle de vie et hooks dans React

Niveau architecte : méthodes de cycle de vie et hooks dans React

WBOY
Libérer: 2024-07-17 18:06:53
original
368 Les gens l'ont consulté

Architect level: Lifecycle Methods and Hooks in React

En tant que développeur de niveau architecte, vous êtes responsable de vous assurer que vos applications sont robustes, maintenables et évolutives. La maîtrise des React Hooks et des méthodes de cycle de vie est essentielle pour atteindre ces objectifs. Cet article couvre les hooks essentiels, les hooks personnalisés et les modèles de hook avancés, tels que la gestion d'états complexes avec useReducer et l'optimisation des performances avec useMemo et useCallback.

Introduction aux crochets React

Les React Hooks, introduits dans React 16.8, permettent aux composants fonctionnels d'utiliser l'état et d'autres fonctionnalités de React. Les hooks offrent une approche fonctionnelle et modulaire de la gestion de la logique des composants, ce qui conduit à des bases de code plus propres et plus maintenables.

Principaux avantages des crochets

  1. Cleaner Code : Les hooks éliminent le besoin de composants de classe, ce qui rend la base de code plus cohérente et plus facile à comprendre.
  2. Réutilisabilité : Les hooks personnalisés permettent l'extraction et la réutilisation de la logique avec état sur plusieurs composants.
  3. Modularité : Les hooks fournissent une API simple pour gérer l'état des composants et les effets secondaires, favorisant ainsi un code modulaire et maintenable.

Crochets essentiels

utiliserÉtat

useState est un hook qui vous permet d'ajouter un état aux composants fonctionnels.

Exemple :

import React, { useState } from 'react';

const Counter = () => {
  const [count, setCount] = useState(0);

  return (
    <div>
      <p>You clicked {count} times</p>
      <button onClick={() => setCount(count + 1)}>Click me</button>
    </div>
  );
};

export default Counter;
Copier après la connexion

Dans cet exemple, useState initialise la variable d'état count à 0. La fonction setCount met à jour l'état lorsque vous cliquez sur le bouton.

utiliserEffet

useEffect est un hook qui vous permet d'effectuer des effets secondaires dans des composants fonctionnels, tels que la récupération de données, l'interaction directe avec le DOM et la configuration d'abonnements. Il combine les fonctionnalités de plusieurs méthodes de cycle de vie dans les composants de classe (componentDidMount, composantDidUpdate et composantWillUnmount).

Exemple :

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

const DataFetcher = () => {
  const [data, setData] = useState(null);

  useEffect(() => {
    fetch('https://api.example.com/data')
      .then(response => response.json())
      .then(data => setData(data));
  }, []);

  return (
    <div>
      {data ? <pre class="brush:php;toolbar:false">{JSON.stringify(data, null, 2)}
: 'Loading...'}
); }; export default DataFetcher;
Copier après la connexion

Dans cet exemple, useEffect récupère les données d'une API lors du montage du composant.

utiliserContext

useContext est un hook qui vous permet d'accéder à la valeur du contexte pour un contexte donné.

Exemple :

import React, { useContext } from 'react';

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

const ThemedComponent = () => {
  const theme = useContext(ThemeContext);

  return <div>The current theme is {theme}</div>;
};

export default ThemedComponent;
Copier après la connexion

Dans cet exemple, useContext accède à la valeur actuelle de ThemeContext.

utiliserRéducteur

useReducer est un hook qui vous permet de gérer une logique d'état complexe dans un composant fonctionnel. C'est une alternative à useState et est particulièrement utile lorsque la logique d'état implique plusieurs sous-valeurs ou lorsque l'état suivant dépend du précédent.

Exemple :

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>
  );
};

export default Counter;
Copier après la connexion
Copier après la connexion

Dans cet exemple, useReducer gère l'état du comptage avec une fonction de réduction.

Crochets personnalisés

Les hooks personnalisés vous permettent de réutiliser la logique avec état sur plusieurs composants. Un hook personnalisé est une fonction qui utilise des hooks intégrés.

Exemple :

import { useState, useEffect } from 'react';

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

  useEffect(() => {
    fetch(url)
      .then(response => response.json())
      .then(data => setData(data));
  }, [url]);

  return data;
};

const DataFetcher = ({ url }) => {
  const data = useFetch(url);

  return (
    <div>
      {data ? <pre class="brush:php;toolbar:false">{JSON.stringify(data, null, 2)}
: 'Loading...'}
); }; export default DataFetcher;
Copier après la connexion

Dans cet exemple, useFetch est un hook personnalisé qui récupère les données d'une URL donnée.

Modèles de crochets avancés

Gestion de l'état complexe avec useReducer

Lorsqu'il s'agit d'une logique d'état complexe impliquant plusieurs sous-valeurs ou lorsque l'état suivant dépend du précédent, useReducer peut être plus approprié que useState.

Exemple :

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>
  );
};

export default Counter;
Copier après la connexion
Copier après la connexion

Dans cet exemple, useReducer gère l'état du comptage avec une fonction de réduction.

Optimiser les performances avec useMemo et useCallback

utiliserMémo

useMemo est un hook qui mémorise une valeur calculée, la recalculant uniquement lorsque l'une des dépendances change. Il permet d'optimiser les performances en évitant des calculs coûteux à chaque rendu.

Exemple :

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

const ExpensiveCalculation = ({ number }) => {
  const computeFactorial = (n) => {
    console.log('Computing factorial...');
    return n <= 1 ? 1 : n * computeFactorial(n - 1);
  };

  const factorial = useMemo(() => computeFactorial(number), [number]);

  return <div>Factorial of {number} is {factorial}</div>;
};

const App = () => {
  const [number, setNumber] = useState(5);

  return (
    <div>
      <input
        type="number"
        value={number}
        onChange={(e) => setNumber(parseInt(e.target.value, 10))}
      />
      <ExpensiveCalculation number={number} />
    </div>
  );
};

export default App;
Copier après la connexion

Dans cet exemple, useMemo garantit que le calcul factoriel n'est recalculé que lorsque le nombre change.

utiliserCallback

useCallback est un hook qui mémorise une fonction, empêchant sa recréation à chaque rendu à moins que l'une de ses dépendances ne change. Il est utile pour transmettre des fonctions stables aux composants enfants qui reposent sur l'égalité de référence.

Exemple :

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

const Button = React.memo(({ onClick, children }) => {
  console.log(`Rendering button - ${children}`);
  return <button onClick={onClick}>{children}</button>;
});

const App = () => {
  const [count, setCount] = useState(0);

  const increment = useCallback(() => setCount((c) => c + 1), []);

  return (
    <div>
      <Button onClick={increment}>Increment</Button>
      <p>Count: {count}</p>
    </div>
  );
};

export default App;
Copier après la connexion

Dans cet exemple, useCallback garantit que la fonction d'incrémentation n'est recréée que si ses dépendances changent, évitant ainsi les nouveaux rendus inutiles du composant Button.

Conclusion

La maîtrise des React Hooks et des méthodes de cycle de vie est essentielle pour créer des applications robustes, maintenables et évolutives. En comprenant et en utilisant des hooks tels que useState, useEffect, useContext et useReducer, ainsi que des modèles avancés tels que des hooks personnalisés et des optimisations de performances avec useMemo et useCallback, vous pouvez créer des applications React efficaces et évolutives. En tant que développeur de niveau architecte, ces compétences amélioreront considérablement votre capacité à concevoir et à guider le développement d'applications React de haute qualité, en garantissant le maintien des meilleures pratiques et des normes élevées tout au long du processus de développement.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:dev.to
Article précédent:Axios Vs Fetch : lequel devriez-vous utiliser pour vos requêtes HTTP ? Article suivant:Conseils pratiques sur les raccourcis jQuery pour un codage efficace
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Derniers numéros
Rubriques connexes
Plus>
Recommandations populaires
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal