Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Войти

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

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

© 2026 YeaHub

Документы

Медиа

Назад
Вопрос про JavaScript: keep, alive, activated

Какие хуки жизненного цикла вызываются при использовании keep-alive?

Вопрос проверяет понимание механизма keep-alive и особенностей жизненного цикла кэшируемых компонентов.

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

При использовании keep-alive компоненты не уничтожаются при скрытии. Вместо стандартных хуков уничтожения используются специальные хуки активации и деактивации. Это activated и deactivated. Они позволяют реагировать на повторное отображение компонента. Такой механизм используется для кэширования состояния.

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

keep-alive — это встроенный компонент Vue, который кэширует динамические компоненты и сохраняет их состояние.

Как работает keep-alive

При оборачивании компонента в keep-alive:

  • Компонент не уничтожается при смене маршрута

  • DOM может быть временно удалён

  • Состояние компонента сохраняется в памяти

Специальные хуки keep-alive

Для работы с кэшируемыми компонентами Vue предоставляет дополнительные хуки.

  1. activated

    • Вызывается при активации компонента

    • Аналог повторного отображения

    • Подходит для обновления данных

  2. deactivated

    • Вызывается при деактивации компонента

    • Компонент скрывается, но не уничтожается

    • Используется для приостановки логики

Пример:

export default {
  activated() {
    // обновление данных при возврате
  },
  deactivated() {
    // пауза таймеров или подписок
  }
};

Отличие от обычного жизненного цикла

  • beforeUnmount и unmounted не вызываются

  • Компонент остаётся в памяти

  • Состояние не сбрасывается

Вывод

При использовании keep-alive жизненный цикл дополняется хуками activated и deactivated, которые позволяют управлять логикой кэшируемых компонентов без их уничтожения.

Уровень

  • Рейтинг:

    3

  • Сложность:

    6

Навыки

  • JavaScript

    JavaScript

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

#keep

#alive

#activated

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