Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про React: controlled, component, uncontrolled

Что такое контролируемые и неконтролируемые компоненты?

Вопрос проверяет понимание управления формами и состоянием ввода в React.

Короткий ответ

Контролируемые компоненты управляются через state.
Неконтролируемые компоненты хранят состояние внутри DOM.
Контролируемые дают больше контроля и предсказуемости.
Неконтролируемые проще, но менее гибкие.

Длинный ответ

Работа с формами — один из базовых сценариев в React.

Определение

  • Контролируемый компонент — значение элемента управляется через state

  • Неконтролируемый компонент — значение хранится в DOM и читается через ref

Контролируемые компоненты

Особенности:

  • значение задаётся через value

  • изменения обрабатываются через onChange

  • состояние всегда синхронизировано с UI

const [value, setValue] = useState('');

<input value={value} onChange={e => setValue(e.target.value)} />

Неконтролируемые компоненты

Особенности:

  • значение хранится в DOM

  • используется defaultValue

  • чтение происходит через ref

<input ref={inputRef} defaultValue="test" />

Сравнение подходов

Контролируемые:

  • проще валидировать

  • удобнее тестировать

  • легче синхронизировать

Неконтролируемые:

  • меньше кода

  • подходят для простых форм

Краткий вывод

Контролируемые компоненты предпочтительны для сложных форм и бизнес-логики. Неконтролируемые подходят для простых сценариев.

Frontend developer

tech
tech
tech
tech
tech
tech
tech
tech
tech

Ментор по Frontend

Полное сопровождение до оффера — без дорогих курсов, с оплатой после трудоустройства

Записаться на консультацию

Уровень

  • Рейтинг:

    5

  • Сложность:

    6

Навыки

  • React

    React

Ключевые слова

#controlled

#component

#uncontrolled

Подпишись на React Developer в телеграм

Frontend developer

tech
tech
tech
tech
tech
tech
tech
tech
tech

Ментор по Frontend

Полное сопровождение до оффера — без дорогих курсов, с оплатой после трудоустройства

Записаться на консультацию