Maison > interface Web > js tutoriel > Pourquoi mon React ne définit-il pas correctement l'état de mise à jour d'intervalle ?

Pourquoi mon React ne définit-il pas correctement l'état de mise à jour d'intervalle ?

Barbara Streisand
Libérer: 2024-12-16 08:04:12
original
845 Les gens l'ont consulté

Why Doesn't My React setInterval Update State Correctly?

React State Hook et setInterval : un examen plus approfondi

Lors de l'utilisation de hooks d'état React dans setInterval, il est important de répondre à une mise en garde courante. . Dans certains cas, l'état peut ne pas se mettre à jour comme prévu au-delà du rendu initial.

Comprendre le problème

Le nœud du problème réside dans la fermeture capturée par setIntervalle. La fonction de rappel fournie à setInterval a accès à la valeur de l'état initial au moment du rendu. Cependant, les rendus suivants n'invoquent pas useEffect(), laissant la fonction de rappel avec une valeur d'état obsolète. Cela fait que le temps reste à 0 dans le rappel setInterval.

Solution : exploitez le formulaire de rappel d'état

Pour résoudre ce problème, utilisez la deuxième forme d'état. hooks, qui accepte un rappel. Ce rappel reçoit l'état actuel comme argument. En utilisant ce formulaire, vous pouvez accéder à la valeur d'état la plus récente avant de l'incrémenter.

setTime(prevTime => prevTime + 1); // Corrected version
Copier après la connexion

Informations supplémentaires

Pour une exploration plus approfondie, le blog perspicace de Dan Abramov post propose des approches alternatives pour résoudre ce problème. Nous vous recommandons fortement de l'approfondir pour une compréhension plus approfondie.

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