Type или interface для props: что выбрать?
Что хотят услышать интервьюеры:
Коротко: Для props подходят и type, и interface; важнее команда convention, unions/intersections и читаемость public API.
Ответ:
Что важно сказать на собеседовании: На собеседовании важно связать эту тему с реальной render-моделью React: где источник данных, что вызывает обновление, какие побочные эффекты допустимы и как это влияет на поддержку интерфейса.
Пример (TypeScript/TSX):
interface LinkProps extends React.ComponentProps<'a'> {
variant?: 'primary' | 'ghost';
}
type Status = 'idle' | 'loading' | 'error'; Типичные ошибки: Типичная ошибка — отвечать только синтаксисом и не объяснять, как решение поведёт себя при повторном render, смене props, unmount или росте данных.
Практический контекст: В практике это встречается в формах, списках, dashboards, личных кабинетах и компонентах design-system; сильный ответ показывает не только API, но и границы применения.