Когда у вас есть несколько фрагментов данных, которые необходимо сохранить в состоянии, вы можете использовать несколько useState
хуков (по одному для каждого значения состояния):
const [id, setId] = useState(2);
const [title, setTitle] = useState('DS STARTS');
// ...
или вы можете использовать один со значением объекта:
const [event, setEvent] = useState({
id: 2,
title: 'DS STARTS',
// ...
Вообще говоря, лучше сделать первое, потому что тогда, когда несвязанные данные изменяются, вы не рендеритесь без необходимости. Но это относится только к несвязанным данным: если все данные концептуально связаны, то сохранение их в одном и том же объекте может иметь смысл.
Например, если у вас есть foo
и bar
с вложенными компонент A, зависящий от foo
, и подкомпонент B, зависящий от bar
и изменений foo
, bar
будут перерисованы (хотя только в виртуальном DOM, при условии, что он возвращает тот же JSX) ... если вы используете один объект состояния для обоих. Если они являются отдельными состояниями, хотя обновление одного не повлияет на компоненты, зависящие от другого.
(Но, опять же, ничего из этого не имеет значения, если и A, и B зависят от обоих foo
и bar
, ie. если данные подключены.)
Кроме того, со значениями объекта вы можете сделать foo.baz = 5
... и забыть, что не будет вызывать повторную визуализацию (у вас есть делать setFoo({...foo, baz: 5})
). У необъектов такой проблемы нет.
Также лично я чувствую, что использование отдельных useState
хуков чище на человеческом уровне, потому что тогда это действительно делает "переменные состояния" более похожими на обычные переменные, в смысл «один на концептуальную часть информации».
PS Если у вас сложное приложение, у вас много состояний: нет способа «решить» это. Но если ваша проблема заключается в необходимости передавать много значений состояний между вашими компонентами, вам следует ознакомиться с контекстом в React, поскольку он предназначен для решения этой проблемы.