Sébastien TIMONER
Expert en développement web et gestion d’équipes techniques, je me spécialise dans la création et l’optimisation de solutions numériques performantes. Grâce à une maîtrise approfondie de technologies modernes comme React.js, Node.js, TypeScript, Symfony et Zephyr OS pour l'IoT, j’assure la réussite de projets SaaS et IoT complexes, de la conception à la mise en production, pour des entreprises de divers secteurs, au sein d'offroadLabs.
Chez offroadLabs, je propose des services de développement sur mesure, alliant expertise technique et approche collaborative. Que ce soit pour créer une solution SaaS innovante, développer des systèmes IoT avec Zephyr OS, moderniser une application existante, ou accompagner la montée en compétences d’une équipe, je m’engage à fournir des solutions robustes et performantes, adaptées aux besoins spécifiques de chaque projet.
Je suis disponible pour des missions autour d’Aix-en-Provence ou en full remote.
Dans les projets React, on utilise souvent useEffect
par réflexe, mais cette approche peut parfois complexifier ton code inutilement. Dans cet article, on va voir des cas où tu n'as pas besoin de useEffect
et comment optimiser ton code en évitant d'y recourir à tort.
useEffect
Le hook useEffect
est utile pour gérer des effets secondaires comme des abonnements ou des opérations qui doivent se déclencher en dehors du flux de rendu principal. Cependant, certains cas d'utilisation courants peuvent être simplifiés sans useEffect
.
useEffect
Tu veux souvent initialiser un état basé sur des props ou des valeurs initiales au montage du composant. Au lieu d'utiliser useEffect
pour définir cet état, tu peux le faire directement avec useState
, ce qui rendra ton code plus clair et préviendra des appels inutiles.
Mauvaise pratique avec useEffect
:
typescript
Bonne pratique sans useEffect
:
Ici, on peut simplement initialiser l’état greeting
en utilisant une fonction dans useState
:
typescript
Cette approche rend le code plus concis et évite d’ajouter un effet superflu qui pourrait ralentir ton application.
Si tu as besoin de calculer une valeur en fonction de l’état ou des props, essaie d’utiliser une variable dérivée ou un memo
plutôt qu’un useEffect
.
Exemple avec useEffect
(à éviter) :
typescript
Solution sans useEffect
:
Ici, la valeur total
peut être calculée directement pendant le rendu, sans dépendre de useEffect
:
typescript
Cette méthode est non seulement plus propre, mais elle élimine le besoin de gérer des états supplémentaires.
useMemo
pour des calculs lourdsPour des calculs coûteux ou dépendants de plusieurs variables, utilise useMemo
afin d’éviter de réexécuter la logique à chaque rendu, sans avoir besoin de useEffect
pour gérer l'état.
Exemple avec useEffect
:
typescript
Approche optimisée avec useMemo
:
typescript
Ici, useMemo
permet de mémoriser le résultat sans avoir à gérer un effet, ce qui rend le composant plus prévisible et performant.
Pour gérer les entrées contrôlées, tu n’as pas besoin d’utiliser useEffect
pour synchroniser les valeurs des inputs avec l'état du composant parent. Utilise simplement les props et les fonctions de rappel pour gérer cet état efficacement.
Exemple avec useEffect
(inutile) :
typescript
Solution sans useEffect
:
typescript
L’utilisation directe des props simplifie le code et améliore la performance en réduisant le nombre de mises à jour d’état inutiles.
Si tu veux appliquer des styles ou des classes basés sur l’état, il est souvent inutile de passer par useEffect
. React gère très bien ce type de synchronisation lors du rendu.
Exemple avec useEffect
:
typescript
Solution sans useEffect
:
typescript
Éviter useEffect
permet souvent de simplifier ton code et d'améliorer les performances de ton application React. En réévaluant les raisons d’utiliser un effet, tu pourras créer des composants plus clairs et éviter des erreurs liées à des dépendances mal configurées. La clé est d’identifier les cas où l'état, les valeurs dérivées, ou useMemo
suffisent pour répondre à tes besoins sans effets secondaires.