Время для прочтения: 1 мин. 5 сек.

Как избежать ненужных перерисовок страницы при помощи pointer-events

Чтобы избавиться от лишних перерисовок страницы Пол Льюис советует отключить эффекты страницы при наведении (игнорировать hover) во время прокрутки её пользователем.

При возникновении события scrollstart добавляем к тегу <body> класс disable-hover, внутри которого прописываем pointer-events: none, а при возникновении события scrollend удаляем этот класс по таймеру:


var timer,
  class = 'disable-hover',
  $body = $('body');
$(window).scroll(function() {
  clearTimeout(timer);
  if (!$body.hasClass(class)) {
   $body.addClass(class);
  }
  timer = setTimeout(function(){
   $body.removeClass(class);
  },500);
});

Кратко описываем наш умный класс:


.disable-hover,
.disable-hover * {
 pointer-events: none !important;
}

И вы на себе почувствуете колоссальный прирост в скорости работы вашего сайта.

Пошерить
Плюсануть
Отправить
Вотсапнуть

Добавить комментарий

Такой e-mail уже зарегистрирован. Воспользуйтесь формой входа или введите другой.

Вы ввели некорректные логин или пароль

Извините, для комментирования необходимо войти.

1. Нажимая на кнопку "Отправить", я даю согласие на обработку персональных данных.

2. Для вставки кода используйте специальные теги [code lang="php"]ваш код[/code]

2 комментария

сначала новые
по рейтингу сначала новые по хронологии

Реально работает, интересно, спасибо)

Не за что - сам пользуюсь )