Maison >interface Web >js tutoriel >Les écouteurs d'événements React affichent-ils des changements d'état inattendus dans les composants fonctionnels ?
Dans cette enquête, nous rencontrons un problème lorsque nous travaillons avec React Hooks. Lorsque vous utilisez un écouteur d'événements pour gérer un clic sur un bouton, le journal de la console affiche un état incorrect.
Dans le CodeSandbox fourni, respectez les étapes suivantes :
Ce comportement est inattendu, car le "Bouton2" de la première carte devrait également afficher la présence de deux cartes.
Ce problème provient d'une gestion différente des gestionnaires d'événements dans les composants CardsProvider et Card.
La résolution de ce problème nécessite un examen attentif de approches de gestion des événements dans les composants fonctionnels à l’aide du hook useState. Voici plusieurs options :
1. État mutable :
Utilisez useRef au lieu de useState pour introduire un objet mutable qui contient l'état actuel. Bien que cette approche permette une mutation directe de l'état, elle va à l'encontre des pratiques recommandées pour le développement de React.
2. Fonction de mise à jour d'état :
Chaque fois qu'un écouteur d'événement est enregistré, transmettez une fonction de mise à jour d'état qui reçoit l'état frais au lieu de l'état obsolète de la portée englobante. Cela garantit que l'écouteur d'événement a toujours accès à l'état le plus à jour.
3. Réenregistrement manuel de l'écouteur d'événement :
Réenregistrez l'écouteur d'événement à chaque fois que l'état change. Cela garantit que le rappel reçoit toujours les dernières informations d'état.
4. Gestion des événements intégrée :
Pour les écouteurs d'événements dans la portée du composant, utilisez la gestion des événements intégrée de React en définissant l'écouteur d'événements directement dans le JSX. Cela élimine le besoin de useEffect et garantit que l'écouteur d'événement reçoit toujours l'état actuel.
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!