Maison >interface Web >js tutoriel >Maîtriser l'optimisation des performances dans React : une plongée approfondie dans useCallback et useMemo

Maîtriser l'optimisation des performances dans React : une plongée approfondie dans useCallback et useMemo

DDD
DDDoriginal
2024-12-03 22:45:11838parcourir

Mastering Performance Optimization in React: A Deep Dive into useCallback and useMemo

Introduction

En tant que développeur frontend travaillant avec React et Next.js, je rencontre souvent des problèmes de performances à mesure que les applications évoluent. L’un des moyens les plus efficaces de résoudre ces problèmes consiste à utiliser des techniques d’optimisation, en particulier à l’aide des hooks useCallback et useMemo. Dans cet article de blog, j'expliquerai le fonctionnement de ces hooks, fournirai des exemples pratiques et illustrerai comment ils peuvent être appliqués dans des projets du monde réel pour améliorer les performances.

Comprendre l'optimisation des performances dans React

React est conçu pour être efficace, mais à mesure que votre application se développe, les performances peuvent souffrir en raison de nouveaux rendus inutiles. Chaque fois qu'un composant est restitué, toutes les fonctions qui y sont définies sont recréées, ce qui peut entraîner des goulots d'étranglement en termes de performances. C'est là que useCallback et useMemo deviennent des outils indispensables pour optimiser vos applications React.

À quoi sert le rappel ?

Le hook useCallback est utilisé pour mémoriser les fonctions. Il renvoie une version mémorisée de la fonction de rappel qui ne change que si l'une de ses dépendances a changé. Ceci est particulièrement utile lors de la transmission de rappels aux composants enfants qui s'appuient sur l'égalité des références pour éviter les rendus inutiles.

const memoizedCallback = useCallback(() => {
  // callback logic
}, [dependencies]);

Exemple concret : soumission de commentaires dans une application de blog

Imaginez que vous créez une section de commentaires pour une application de blog. Chaque soumission de commentaire déclenche un nouveau rendu de la liste de commentaires. En utilisant useCallback, vous pouvez optimiser le gestionnaire de soumission pour éviter les nouveaux rendus inutiles.

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

const CommentSection = ({ postId }) => {
  const [comments, setComments] = useState([]);
  const [newComment, setNewComment] = useState('');

  const handleCommentSubmission = useCallback(() => {
    setComments((prevComments) => [...prevComments, newComment]);
    setNewComment('');
  }, [newComment]);

  return (
    <div>
      <h2>Comments</h2>
      <ul>
        {comments.map((comment, index) => (
          <li key={index}>{comment}</li>
        ))}
      </ul>
      <input
        type="text"
        value={newComment}
        onChange={(e) => setNewComment(e.target.value)}
      />
      <button onClick={handleCommentSubmission}>Submit</button>
    </div>
  );
};

Dans cet exemple, la fonction _handleCommentSubmission _est mémorisée. Il ne sera recréé que si newComment change, évitant ainsi les rendus inutiles de tout composant enfant qui dépend de cette fonction.

Qu'est-ce que useMemo ?

Le hook useMemo est utilisé pour mémoriser des calculs coûteux. Il renvoie une valeur mémorisée qui n'est recalculée que lorsque l'une de ses dépendances change. Cela permet d'éviter des recalculs coûteux à chaque rendu.

const memoizedValue = useMemo(() => {
  // Expensive calculation
  return computedValue;
}, [dependencies]);

Exemple concret : filtrage de grands ensembles de données

Considérez une application qui affiche une grande liste de produits. Lors du filtrage de cette liste en fonction des entrées de l'utilisateur, le recalcul des résultats filtrés à chaque rendu peut s'avérer inefficace. En utilisant useMemo, vous pouvez optimiser ce processus.

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

const ProductList = ({ products }) => {
  const [filterText, setFilterText] = useState('');

  const filteredProducts = useMemo(() => {
    return products.filter((product) =>
      product.name.toLowerCase().includes(filterText.toLowerCase())
    );
  }, [filterText, products]);

  return (
    <div>
      <input
        type="text"
        placeholder="Search products..."
        value={filterText}
        onChange={(e) => setFilterText(e.target.value)}
      />
      <ul>
        {filteredProducts.map((product) => (
          <li key={product.id}>{product.name}</li>
        ))}
      </ul>
    </div>
  );
};

Dans cet exemple, le tableau filteredProducts est calculé uniquement lorsque filterText ou products change. Cela évite les calculs de filtrage inutiles lors des rendus lorsque d'autres variables d'état changent.

Bonnes pratiques d'utilisation de useCallback et useMemo

  1. Utiliser lorsque cela est nécessaire : implémentez ces hooks uniquement lorsque vous remarquez des problèmes de performances dus à des rendus fréquents ou à des calculs coûteux.

  2. Gardez les dépendances précises : assurez-vous que vos tableaux de dépendances sont corrects pour éviter les fermetures obsolètes ou les valeurs incorrectes.

  3. Combiner avec React.memo : utilisez React.memo pour les composants enfants à côté de ces hooks pour des performances optimales.

Conclusion

L'optimisation des performances dans les applications React est cruciale pour offrir une expérience utilisateur fluide. En utilisant efficacement useCallback et useMemo, vous pouvez minimiser les rendus inutiles et les calculs coûteux dans vos composants. Alors que vous poursuivez votre parcours en tant que développeur frontend, gardez ces outils à l'esprit et appliquez-les judicieusement pour améliorer l'efficacité de vos applications.

N'hésitez pas à partager vos réflexions ou à poser des questions dans les commentaires ci-dessous ! Vos commentaires m'aident à améliorer et à créer du contenu plus précieux pour les autres développeurs. Bon codage !

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!

Déclaration:
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