چطور با استفاده از هوک useState به یک آرایه عنصر جدید اضافه کنم؟ ( React JS )
How to push to an array using useState hook?
من دارم از هوک useState توی ریاکت استفاده میکنم و میخوام یه آیتم جدید به یه آرایهای که توی state ذخیره شده اضافه کنم. اما مطمئن نیستم چطوری باید این کارو درست انجام بدم. چطور میتونم بدون این که state رو مستقیما دستکاری کنم، یه آیتم جدید به آرایه اضافه کنم؟
برای اینکه یه آیتم جدید به آرایهای که توی state ذخیره شده اضافه کنی، باید به نکتهای مهم توجه داشته باشی: نباید مستقیماً state رو تغییر بدی، چون این کار باعث میشه ریاکت نفهمه که state تغییر کرده و در نتیجه کامپوننت بهروز نمیشه. برای اینکه این مشکل پیش نیاد، باید از تابع setter که useState بهت میده استفاده کنی.
برای اضافه کردن آیتم جدید به آرایه، میتونی از تابع setItems استفاده کنی که از useState به دست آوردی. کاری که باید بکنی اینه که یه نسخه جدید از آرایه قبلی ایجاد کنی و آیتم جدید رو به اون اضافه کنی. مثلا به این شکل:
const [items, setItems] = useState([]); const addItem = newItem => { setItems(prevItems => [...prevItems, newItem]); };
توضیح کد:
- setItems تابعیه که برای بهروزرسانی state استفاده میشه.
- prevItems آرایهایه که قبل از بهروزرسانی به عنوان state ذخیره شده.
- [...prevItems, newItem] یه نسخه جدید از آرایه میسازه که شامل همه آیتمهای قبلی به همراه آیتم جدیده.
این روش بهترین راه برای اضافه کردن آیتم به آرایه است، چون نه تنها state رو تغییر میده، بلکه یه آرایه جدید میسازه که ریاکت بفهمه باید دوباره کامپوننت رو رندر کنه.
نکته مهم اینه که هیچ وقت نباید به طور مستقیم items.push(newItem) رو استفاده کنی، چون این کار state رو مستقیما تغییر میده و مشکلاتی توی بهروزرسانی کامپوننتها به وجود میاره.
پس خلاصه که بگم: همیشه از setItems و سینتکس ... (سه نقطه) برای اضافه کردن آیتم جدید استفاده کن. این روش هم تمیزه و هم باعث میشه کامپوننتهات درست کار کنن.