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

Как сделать появления и пропадания блока при скролле?

Добрый день! У меня есть вопрос. Как сделать, чтобы при скролле вниз блок появлялся, а при скролле вверх исчезал
  • Вопрос задан
  • 65 просмотров
Подписаться 1 Средний Комментировать
Решения вопроса 1
@eternalfire
function debounce(func, wait = 10, immediate = true) {
      let timeout;
      return function() {
        let context = this, args = arguments;
        let later = function() {
          timeout = null;
          if (!immediate) func.apply(context, args);
        };
        let callNow = immediate && !timeout;
        clearTimeout(timeout);
        timeout = setTimeout(later, wait);
        if (callNow) func.apply(context, args);
      };
    };

    let scrollPos = 0;
    const nav = document.querySelector('.site-nav');

    function checkPosition() {
      let windowY = window.scrollY;
      if (windowY < scrollPos) {
        nav.classList.add('is-visible');
        nav.classList.remove('is-hidden');
      } else {
        nav.classList.add('is-hidden');
        nav.classList.remove('is-visible');
      }
      scrollPos = windowY;
    }
    window.addEventListener('scroll', debounce(checkPosition));


Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
@marki1404 Автор вопроса
Можете пожалуйста сбросить ссылку на Codepen, или что-то подобное?
Ответ написан
Ваш ответ на вопрос

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

Похожие вопросы