


Pourquoi l'événement Onchange dans React Fire plusieurs fois lors de la saisie?
L'événement Onchange se déclenche plusieurs fois dans React: Discussion approfondie
Dans le développement de React, l'événement onChange
de la boîte d'entrée est parfois déclenché accidentellement plusieurs fois. Cet article analysera ce problème en profondeur et fournira une solution.
Description du problème
Un composant de réaction simple qui gère l'état à l'aide useState
et met à jour l'état et imprime dans onChange
dans la zone d'entrée. Cependant, lors de la saisie d'un personnage, la console imprime deux fois. Ce phénomène est particulièrement évident lors de l'utilisation d'états de type objet, mais ne se produit pas lors de l'utilisation d'états de type primitif.
Exemple d'extrait de code (code de problème):
Importer React, {UseState} de "React"; Exporter la fonction default child () { const [state, setState] = UseState ({}); const onchange = (event) => { setState ({... état, valeur: event.target.value}); Console.log ("Onchange déclenché", État); }; Retour ( <div> <input type="text" onchange="{onChange}"> </div> )); }
Analyse des problèmes
La racine de ce problème réside dans le mode strict de React. Dans un environnement de développement, le mode strict effectue deux rendus pour aider les développeurs à découvrir des problèmes potentiels, tels que des effets secondaires inutiles.
Lorsque l'état est type d'objet, setState
met à jour la référence à l'objet, pas la valeur elle-même. Le double rendu du mode strict fait que onChange
est appelé deux fois, chaque fois que la même référence d'objet est mise à jour. L'état de type d'origine (tel que les chaînes, les nombres) met directement à jour la valeur, donc ce problème ne se produira pas.
cause première
- Mise à jour de référence de l'état du type d'objet: Lors de l'utilisation d'un objet comme état,
setState
créera un nouvel objet, maisconsole.log
à l'intérieur de la fonctiononChange
imprime toujours l'ancien état en raison du mécanisme de mise à jour asynchrone de React. Le statut est mis à jour sur une nouvelle valeur uniquement lors du deuxième rendu. - Double rendu de mode strict: le mode strict dans l'environnement de développement déclenche le rendu double, exacerbant ce problème.
Solution
Évitez d'utiliser l'état de type d'objet ou optimisez la méthode d'appel de setState
:
Méthode 1: Utilisez l'état de type d'origine
Changez l'état en type d'origine, comme une chaîne:
Importer React, {UseState} de "React"; Exporter la fonction default child () { const [inputValue, setInputValue] = UseState (""); const onchange = (event) => { setInputValue (event.target.Value); Console.log ("OnChange déclenché", InputValue); }; Retour ( <div> <input type="text" value="{inputValue}" onchange="{onChange}"> </div> )); }
Méthode 2: Utilisez des mises à jour fonctionnelles
Utilisez des mises à jour fonctionnelles setState
pour vous assurer que chaque mise à jour est basée sur le dernier état:
Importer React, {UseState} de "React"; Exporter la fonction default child () { const [state, setState] = UseState ({}); const onchange = (event) => { setState ((prevState) => ({... prevState, valeur: event.target.value})); Console.log ("Onchange déclenché", État); }; Retour ( <div> <input type="text" onchange="{onChange}"> </div> )); }
Grâce aux méthodes ci-dessus, le problème du déclenchement des événements onChange
plusieurs fois dans React peut être résolu efficacement. N'oubliez pas que le mode strict est désactivé dans les environnements de production, donc ce problème ne se produit généralement que dans les environnements 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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Voulez-vous savoir comment afficher les catégories d'enfants sur la page des archives de la catégorie parent? Lorsque vous personnalisez une page d'archive de classification, vous devrez peut-être le faire pour le rendre plus utile à vos visiteurs. Dans cet article, nous vous montrerons comment afficher facilement les catégories d'enfants sur la page des archives de la catégorie parent. Pourquoi les sous-catégories apparaissent-elles sur la page des archives de la catégorie des parents? En affichant toutes les catégories d'enfants sur la page des archives de la catégorie parent, vous pouvez les rendre moins génériques et plus utiles aux visiteurs. Par exemple, si vous exécutez un blog WordPress sur les livres et que vous avez une taxonomie appelée "thème", vous pouvez ajouter une sous-taxonomie telle que "roman", "non-fiction" afin que vos lecteurs puissent

Comment la solution de mise en cache Redis réalise-t-elle les exigences de la liste de classement des produits? Pendant le processus de développement, nous devons souvent faire face aux exigences des classements, comme l'affichage d'un ...

Les facteurs de la hausse des prix des devises virtuels comprennent: 1. Une augmentation de la demande du marché, 2. Daisser l'offre, 3. Stimulé de nouvelles positives, 4. Sentiment du marché optimiste, 5. Environnement macroéconomique; Les facteurs de déclin comprennent: 1. Daissement de la demande du marché, 2. AUGMENT DE L'OFFICATION, 3. Strike of Negative News, 4. Pespimiste Market Sentiment, 5. Environnement macroéconomique.

Comprendre le caractère aléatoire des dépendances circulaires dans le démarrage du projet Spring. Lors du développement du projet Spring, vous pouvez rencontrer le caractère aléatoire causé par des dépendances circulaires au démarrage du projet ...

Pourquoi la valeur de retour est-elle vide lors de l'utilisation de Redemplate pour la requête par lots? Lorsque vous utilisez Redemplate pour les opérations de requête par lots, vous pouvez rencontrer les résultats renvoyés ...

La solution d'optimisation pour les tâches de synchronisation Springboot dans un environnement multi-nœuds développe le ressort ...

Discussion sur les raisons pour lesquelles JavaScript ne peut pas obtenir d'informations sur le matériel informatique de l'utilisateur dans la programmation quotidienne, de nombreux développeurs seront curieux de savoir pourquoi JavaScript ne peut pas être directement obtenu ...

Concordium: une plate-forme publique de blockchain de premier niveau qui prend en compte la confidentialité et la conformité est une plate-forme publique de blockchain de premier niveau. Son cœur réside dans l'intégration intelligente de la vérification de l'identité avec la vie privée et la conformité réglementaire. Fondée en 2018 par Lars Seier Christensen, la technologie principale de la plate-forme intégré les identités cryptographiques au niveau du protocole de chaque transaction. Cette conception unique garantit la traçabilité des responsabilités tout en protégeant la confidentialité des utilisateurs, résolvant efficacement le problème des conflits entre l'anonymat et les exigences réglementaires dans le champ Blockchain. Pour atténuer ce problème, Concordium utilise la technologie zéro preuve de connaissances (ZKP), permettant aux utilisateurs de vérifier les attributs d'identité spécifiques sans avoir besoin de divulguer des informations personnelles inutiles. Cela signifie que, malgré chaque
