@maiskiykot
Free coder

Как отменить setTimeout по событию скроллинг мышью?

Есть список, формируемый по Ajax из элементов li. Он имеет прокрутку из-за большого размера. Когда пользователь начинает прокручивать список нужно обработать это событие и отменить выполнение скрипта по setTimeout. Загвоздка у меня в том: как прописать это? Список формируется динамически, а значит в html не добавить событие. И какое событие нужно в данном случае? onMouseMove или что?
  • Вопрос задан
  • 291 просмотр
Решения вопроса 1
rockon404
@rockon404
Frontend Developer
var timeout = setTimeout(handler, duration);

element.addEventListener('scroll', scrollHandler);

function scrollHandler() {
  clearTimeout(timeout);
  element.removeEventListener('scroll', scrollHandler);
}

или:
var timeout = setTimeout(handler, duration);

element.addEventListener('scroll', function() {
  if (timeout) {
    clearTimeout(timeout);
    timeout = null;
  }
});


где element - элемент на котором вы хотите обрабатывать событие scroll.

В первом случае слушатель события scroll, по первому событию отменяется. Во втором остается и если таймер будет переназначен, по scroll он снова будет отменен.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

Похожие вопросы
24 нояб. 2024, в 03:11
500 руб./за проект
24 нояб. 2024, в 01:35
5000 руб./за проект
24 нояб. 2024, в 01:24
500 руб./за проект