Как отменять fetch в useEffect?

ReactMiddleAsync and data fetchingПрактикаfetchabortcontrolleruseEffect

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

Коротко: AbortController отменяет fetch при unmount или смене параметров, чтобы старый запрос не обновил state.

Ответ:

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

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

useEffect(() => {
  const controller = new AbortController();
  fetch(`/api/users/${userId}`, { signal: controller.signal })
    .then((res) => res.json())
    .then(setUser)
    .catch((error) => { if (error.name !== 'AbortError') setError(error); });
  return () => controller.abort();
}, [userId]);

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

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

Источники

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