Назад к вопросам
Junior
10
// мутирует текущие state -> setPhotos([...photos, photo]); // не увидет изменения // мутирует переменную // нет ключа
Компании, где спрашивали
ARTW
Ответ от нейросети
sobes.tech AI
В React важно не мутировать текущий state напрямую, а создавать новый объект или массив, чтобы React мог обнаружить изменения и обновить компонент.
Например, если у вас есть массив photos в состоянии, то правильное обновление выглядит так:
setPhotos([...photos, photo]);
Здесь создаётся новый массив с добавленным элементом, и React увидит изменение.
Если же мутировать переменную напрямую, например, делать photos.push(photo), React не увидит изменений, и UI не обновится.
Также важно указывать уникальный ключ (key) для элементов списка при рендеринге, чтобы React мог эффективно отслеживать изменения:
{photos.map(photo => (
<img key={photo.id} src={photo.url} alt="photo" />
))}
Без ключа React может неправильно обновлять элементы списка.