Maison > interface Web > js tutoriel > le corps du texte

Pourquoi devriez-vous éviter les fonctions fléchées ou les liaisons dans les accessoires JSX ?

Linda Hamilton
Libérer: 2024-11-06 20:27:03
original
588 Les gens l'ont consulté

Why Should You Avoid Arrow Functions or Binding in JSX Props?

Pourquoi utiliser les fonctions fléchées ou Bind dans les accessoires JSX est un non-non

Lors de l'utilisation de React, il est important d'éviter d'utiliser des fonctions fléchées ou liaison dans les accessoires JSX. Cette pratique peut entraîner des problèmes de performances et un comportement incorrect.

Mauvais performances

L'utilisation de fonctions fléchées ou de liaisons dans les accessoires JSX force la recréation de ces fonctions à chaque rendu. Cela signifie que :

  • L'ancienne fonction est supprimée, déclenchant le garbage collection.
  • Le rendu continu de nombreux éléments peut entraîner une instabilité des performances.
  • Les composants s'appuyant sur PureComponents ou ShouldComponentUpdate déclenche toujours des rendus en raison de la modification de l'accessoire de fonction de flèche.

Comportement incorrect

Considérez l'exemple suivant :

onClick={() => this.handleDelete(tile)}
Copier après la connexion

Ce code créera une nouvelle fonction à chaque rendu, obligeant React à marquer le composant comme sale et à déclencher un nouveau rendu. Même si l'accessoire de tuile n'a pas changé, le composant sera restitué car la fonction de la flèche est différente.

Bonnes pratiques

Pour éviter ces pièges, utilisez l'option bonnes pratiques suivantes :

  • Lier le gestionnaire d'événements dans le constructeur :
constructor(props) {
  super(props);
  this.handleDelete = this.handleDelete.bind(this);
}
Copier après la connexion
  • Créer une fonction de flèche à l'extérieur de la méthode de rendu :
const handleDelete = tile => {
  // Handle delete logic
};
Copier après la connexion

Remarque supplémentaire :

Il est important de noter que les fonctions fléchées conviennent parfaitement lorsqu'elles sont utilisées dans d'autres parties du composant, comme dans la méthode de rendu. Cependant, ils doivent être évités lors de l'attribution de gestionnaires d'événements aux accessoires JSX.

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:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!