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

Как докрутить страницу после метода ScrollIntoView?

Есть 4 блока, при клике на пункт в навигации, нужно прокрутить до блока. Всё работало, но когда я сделал position: sticky, чтобы после того как навигация прокручивалась, она оставалась сверху всегда, и сейчас прокручивается как надо, но шапка закрывает заголовок того блока куда прокрутилась страница.

Как переписать функцию, или что можно добавить чтобы она примерно на 90 пикселей прокручивалась?

openAnchor: function (numberAnchor) {
        event.preventDefault();
        let anchor = this.$refs[`anchor-${numberAnchor}`];
        anchor.scrollIntoView({behavior: "smooth", block: "start"});
      }
  • Вопрос задан
  • 1501 просмотр
Подписаться 1 Средний Комментировать
Решения вопроса 1
@Demonstr66
Не уверен, как работает sticky, но судя по всему он не считается в основном потоке елементов DOM, поэтому при скролле надо задать offset, пример стыренный со stackOverflow
const id = 'block';
      const yOffset = -50; 
      const element = document.getElementById(id);
      const y = element.getBoundingClientRect().top + window.pageYOffset + yOffset;

      window.scrollTo({top: y, behavior: 'smooth'});
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

Похожие вопросы
23 дек. 2024, в 11:07
10000 руб./за проект
23 дек. 2024, в 10:43
5000 руб./за проект
23 дек. 2024, в 10:32
2000 руб./за проект