Table des matières
L'événement Onchange se déclenche plusieurs fois dans React: Discussion approfondie
Description du problème
Analyse des problèmes
cause première
Solution
Maison interface Web js tutoriel Pourquoi l'événement Onchange dans React Fire plusieurs fois lors de la saisie?

Pourquoi l'événement Onchange dans React Fire plusieurs fois lors de la saisie?

Apr 04, 2025 pm 07:12 PM
Pourquoi red

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>
  ));
}
Copier après la connexion

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, mais console.log à l'intérieur de la fonction onChange 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>
  ));
}
Copier après la connexion

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>
  ));
}
Copier après la connexion

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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

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 !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Comment afficher les catégories d'enfants sur la page des archives des catégories de parents Comment afficher les catégories d'enfants sur la page des archives des catégories de parents Apr 19, 2025 pm 11:54 PM

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 utiliser la solution Redis Cache pour réaliser efficacement les exigences de la liste de classement des produits? Comment utiliser la solution Redis Cache pour réaliser efficacement les exigences de la liste de classement des produits? Apr 19, 2025 pm 11:36 PM

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 ...

Pourquoi la hausse ou la baisse des prix de monnaie virtuelle? Pourquoi la hausse ou la baisse des prix de monnaie virtuelle? Pourquoi la hausse ou la baisse des prix de monnaie virtuelle? Pourquoi la hausse ou la baisse des prix de monnaie virtuelle? Apr 21, 2025 am 08:57 AM

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.

Pourquoi le projet de printemps provoque-t-il des problèmes de hasard dus aux dépendances circulaires lors du démarrage? Pourquoi le projet de printemps provoque-t-il des problèmes de hasard dus aux dépendances circulaires lors du démarrage? Apr 19, 2025 pm 11:21 PM

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? Pourquoi la valeur de retour est-elle vide lors de l'utilisation de Redemplate pour la requête par lots? Apr 19, 2025 pm 10:15 PM

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 ...

Dans un environnement multi-nœuds, comment s'assurer que la tâche de synchronisation @Scheduled de Spring Boot est exécutée uniquement sur un seul nœud? Dans un environnement multi-nœuds, comment s'assurer que la tâche de synchronisation @Scheduled de Spring Boot est exécutée uniquement sur un seul nœud? Apr 19, 2025 pm 10:57 PM

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

Pourquoi JavaScript ne peut-il pas obtenir directement des informations matérielles sur l'ordinateur de l'utilisateur? Pourquoi JavaScript ne peut-il pas obtenir directement des informations matérielles sur l'ordinateur de l'utilisateur? Apr 19, 2025 pm 08:15 PM

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 ...

Pourquoi devriez-vous écouter Pourquoi devriez-vous écouter Apr 21, 2025 pm 09:00 PM

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

See all articles