Когда useReducer лучше useState?
Что хотят услышать интервьюеры:
Коротко: useReducer лучше для сложного состояния с явными событиями и связанными переходами.
Ответ:
Что важно сказать на собеседовании: На собеседовании важно связать эту тему с реальной render-моделью React: где источник данных, что вызывает обновление, какие побочные эффекты допустимы и как это влияет на поддержку интерфейса.
Пример (React/TSX):
function reducer(state, action) {
switch (action.type) {
case 'add': return { ...state, items: [...state.items, action.item] };
case 'clear': return { ...state, items: [] };
default: return state;
}
}
const [state, dispatch] = useReducer(reducer, { items: [] }); Типичные ошибки: Типичная ошибка — отвечать только синтаксисом и не объяснять, как решение поведёт себя при повторном render, смене props, unmount или росте данных.
Практический контекст: В практике это встречается в формах, списках, dashboards, личных кабинетах и компонентах design-system; сильный ответ показывает не только API, но и границы применения.