Задать вопрос

Как приостановить setInterval при наведении на кнопку?

Имеется функция:
async function elUp(selector) {
  try {
    var html = await (await fetch(location.href)).text();
    var newdoc = new DOMParser().parseFromString(html, 'text/html');
    document.querySelector(selector).outerHTML = newdoc.querySelector(selector).outerHTML;
    return true;
  } catch(err) {return false;}
}

и собственно имеется сам window.setInterval("elUp('#reload')", 1000); который обновляет к примеру блок <div id="reload"></div>

Вопрос, как при наведении курсора на кнопку приостановить выполнение setInterval, а потом, когда курсор убран, запускать?

P.S. Кнопка находится внутри блока #reload
  • Вопрос задан
  • 151 просмотр
Подписаться 1 Простой 4 комментария
Решения вопроса 1
@sasmoney
// Создание переменной для хранения идентификатора интервала
let intervalId;

// Функция, которую вы хотите выполнить внутри setInterval
function updateElement(selector) {
  // Ваш код обновления элемента
  console.log('Обновление элемента:', selector);
}

// Функция для приостановки выполнения setInterval
function pauseInterval() {
  clearInterval(intervalId);
}

// Функция для возобновления выполнения setInterval
function resumeInterval(selector) {
  intervalId = setInterval(() => {
    updateElement(selector);
  }, 1000);
}
// Обработчик события наведения курсора на кнопку
document.querySelector('#reload').addEventListener('mouseenter', () => {
  pauseInterval();
});

// Обработчик события убирания курсора с кнопки
document.querySelector('#reload').addEventListener('mouseleave', () => {
  resumeInterval('#reload');
});

// Запуск интервала при загрузке страницы
resumeInterval('#reload');
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
Rocket Смоленск
от 80 000 до 130 000 ₽
Wanted. Москва
от 250 000 до 400 000 ₽
Wanted. Санкт-Петербург
До 220 000 ₽
26 дек. 2024, в 23:03
500 руб./в час
26 дек. 2024, в 21:50
5000 руб./за проект
26 дек. 2024, в 21:01
10000 руб./за проект