Как проектировать границу между React UI и data layer?
Что хотят услышать интервьюеры:
Коротко: UI-компоненты не должны знать transport/cache; data layer предоставляет hooks, а компонент описывает loading/error/data.
Ответ:
Что важно сказать на собеседовании: На собеседовании важно связать эту тему с реальной render-моделью React: где источник данных, что вызывает обновление, какие побочные эффекты допустимы и как это влияет на поддержку интерфейса.
Пример (React/TSX):
function UserCard({ userId }) {
const { data, isLoading, error } = useUser(userId);
if (isLoading) return <Spinner />;
if (error) return <ErrorMessage error={error} />;
return <Profile user={data} />;
} Типичные ошибки: Типичная ошибка — отвечать только синтаксисом и не объяснять, как решение поведёт себя при повторном render, смене props, unmount или росте данных.
Практический контекст: В практике это встречается в формах, списках, dashboards, личных кабинетах и компонентах design-system; сильный ответ показывает не только API, но и границы применения.