Le hook useState de React est un outil fondamental pour gérer l'état des composants fonctionnels. Bien que de nombreux développeurs connaissent son utilisation de base, le modèle de rappel dans useState est souvent négligé et pourtant incroyablement puissant. Dans cet article, nous explorerons quand et pourquoi utiliser les fonctions de rappel avec useState, avec des exemples pratiques.
Avant de plonger dans les rappels, actualisons rapidement le fonctionnement typique de useState :
const [count, setCount] = useState(0); // Later in your component... setCount(count + 1);
Le modèle de rappel devient important lorsque vous mettez à jour l'état en fonction de sa valeur précédente. Alors que vous pourriez être tenté d'écrire :
const [count, setCount] = useState(0); // ? This might not work as expected const handleMultipleIncrements = () => { setCount(count + 1); setCount(count + 1); setCount(count + 1); };
Ce code n'incrémentera pas le décompte de 3 comme on pourrait s'y attendre. En raison du traitement par lots d'état de React, toutes ces mises à jour seront basées sur la même valeur originale de count.
Voici où la fonction de rappel brille :
const handleMultipleIncrements = () => { setCount(prevCount => prevCount + 1); setCount(prevCount => prevCount + 1); setCount(prevCount => prevCount + 1); };
Désormais, chaque mise à jour est basée sur l'état précédent, garantissant que tous les incréments sont correctement appliqués.
Regardons un exemple pratique de gestion d'un panier :
function ShoppingCart() { const [items, setItems] = useState([]); const addItem = (product) => { setItems(prevItems => { // Check if item already exists const existingItem = prevItems.find(item => item.id === product.id); if (existingItem) { // Update quantity of existing item return prevItems.map(item => item.id === product.id ? { ...item, quantity: item.quantity + 1 } : item ); } // Add new item return [...prevItems, { ...product, quantity: 1 }]; }); }; // ... rest of the component }
// ✅ Good setItems(prev => [...prev, newItem]); // ? Bad - Don't mutate previous state setItems(prev => { prev.push(newItem); // Mutating state directly return prev; });
const [items, setItems] = useState<CartItem[]>([]); setItems((prev: CartItem[]) => [...prev, newItem]);
Voici un exemple plus complexe montrant comment les rappels peuvent gérer des mises à jour d'état sophistiquées :
function TaskManager() { const [tasks, setTasks] = useState([]); const completeTask = (taskId) => { setTasks(prevTasks => prevTasks.map(task => task.id === taskId ? { ...task, status: 'completed', completedAt: new Date().toISOString() } : task )); }; const addSubtask = (taskId, subtask) => { setTasks(prevTasks => prevTasks.map(task => task.id === taskId ? { ...task, subtasks: [...(task.subtasks || []), subtask] } : task )); }; }
L'utilisation des fonctions de rappel avec useState est essentielle pour des mises à jour d'état fiables dans React. Ils aident à prévenir les conditions de concurrence critique, garantissent que les mises à jour d'état sont basées sur les valeurs les plus récentes et rendent votre code plus prévisible. Même si la syntaxe peut paraître plus verbeuse au premier abord, les avantages en termes de fiabilité et de maintenabilité en valent la peine.
N'oubliez pas : si votre nouvel état dépend de quelque manière que ce soit de l'état précédent, utilisez le modèle de rappel. Votre futur moi (et votre équipe) vous remerciera !
Vous avez des questions ou des commentaires ? N'hésitez pas à nous contacter ou à laisser un commentaire ci-dessous !
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!