Как использовать reducer для сложной формы?
Что хотят услышать интервьюеры:
Коротко: Reducer помогает описать события формы: change field, validate, submit, reset — особенно когда поля зависят друг от друга.
Ответ:
Что важно сказать на собеседовании: На собеседовании важно связать эту тему с реальной render-моделью React: где источник данных, что вызывает обновление, какие побочные эффекты допустимы и как это влияет на поддержку интерфейса.
Пример (React/TSX):
function formReducer(state, action) {
if (action.type === 'change') {
return { ...state, values: { ...state.values, [action.name]: action.value } };
}
if (action.type === 'reset') return initialState;
return state;
} Типичные ошибки: Типичная ошибка — отвечать только синтаксисом и не объяснять, как решение поведёт себя при повторном render, смене props, unmount или росте данных.
Практический контекст: В практике это встречается в формах, списках, dashboards, личных кабинетах и компонентах design-system; сильный ответ показывает не только API, но и границы применения.