@sickgang

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

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

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

openAnchor: function (numberAnchor) {
        event.preventDefault();
        let anchor = this.$refs[`anchor-${numberAnchor}`];
        anchor.scrollIntoView({behavior: "smooth", block: "start"});
      }
  • Вопрос задан
  • 1496 просмотров
Решения вопроса 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, в 01:31
1000 руб./за проект
23 нояб. 2024, в 00:16
2000 руб./за проект
22 нояб. 2024, в 23:55
3000 руб./за проект