Когда нужен useImperativeHandle?
Что хотят услышать интервьюеры:
Коротко: useImperativeHandle позволяет expose ограниченный imperative API через ref для focus, scroll, modal или media controls.
Ответ:
Что важно сказать на собеседовании: На собеседовании важно связать эту тему с реальной render-моделью React: где источник данных, что вызывает обновление, какие побочные эффекты допустимы и как это влияет на поддержку интерфейса.
Пример (React/TSX):
const Modal = forwardRef(function Modal(_, ref) {
const dialogRef = useRef(null);
useImperativeHandle(ref, () => ({
open: () => dialogRef.current?.showModal(),
close: () => dialogRef.current?.close(),
}));
return <dialog ref={dialogRef} />;
}); Типичные ошибки: Типичная ошибка — отвечать только синтаксисом и не объяснять, как решение поведёт себя при повторном render, смене props, unmount или росте данных.
Практический контекст: В практике это встречается в формах, списках, dashboards, личных кабинетах и компонентах design-system; сильный ответ показывает не только API, но и границы применения.