Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

Документы

Медиа

Назад
Вопрос про React: useeffect, cleanup

Как реализовать cleanup-функцию в useEffect?

Вопрос проверяет понимание очистки побочных эффектов и предотвращения утечек памяти.

Короткий ответ

Cleanup-функция реализуется возвратом функции из useEffect. Эта функция вызывается перед повторным выполнением эффекта и при размонтировании компонента. Cleanup используется для очистки таймеров, подписок и слушателей событий. Это предотвращает утечки памяти и некорректное поведение.

Длинный ответ

Любой эффект, который что-то “подписывает” или создаёт ресурс, должен уметь его очищать.

Определение

Cleanup-функция — функция, возвращаемая из useEffect, предназначенная для очистки побочного эффекта.

Пример с подпиской

useEffect(() => {
  const handler = () => console.log("resize");
  window.addEventListener("resize", handler);

  return () => {
    window.removeEventListener("resize", handler);
  };
}, []);

Пример с таймером

useEffect(() => {
  const id = setInterval(() => {
    console.log("tick");
  }, 1000);

  return () => clearInterval(id);
}, []);

Когда cleanup обязателен

  1. События (addEventListener).

  2. Таймеры (setTimeout, setInterval).

  3. Подписки (WebSocket, RxJS).

  4. Сторонние библиотеки.

Вывод

Cleanup-функция — обязательная часть корректного useEffect, если эффект создаёт долгоживущие ресурсы.

Уровень

  • Рейтинг:

    5

  • Сложность:

    4

Навыки

  • React

    React

Ключевые слова

#useeffect

#cleanup

Подпишись на React Developer в телеграм