Почему file input обычно uncontrolled?

ReactJuniorForms and eventsПодвохfile-inputforms

Что хотят услышать интервьюеры:

Коротко: File input нельзя полноценно контролировать через value из React state; файлы читают из event или ref.

Ответ:

Что важно сказать на собеседовании: На собеседовании важно связать эту тему с реальной render-моделью React: где источник данных, что вызывает обновление, какие побочные эффекты допустимы и как это влияет на поддержку интерфейса.

Пример (React/TSX):

function Upload() {
  function onChange(e) {
    const file = e.target.files?.[0];
    if (file) console.log(file.name);
  }
  return <input type="file" onChange={onChange} />;
}

Типичные ошибки: Типичная ошибка — отвечать только синтаксисом и не объяснять, как решение поведёт себя при повторном render, смене props, unmount или росте данных.

Практический контекст: В практике это встречается в формах, списках, dashboards, личных кабинетах и компонентах design-system; сильный ответ показывает не только API, но и границы применения.

Источники

Похожие вопросы