Решение перекрытия контента фиксированным заголовком в HTML

Пройдите тест, узнайте какой профессии подходите

Я предпочитаю
0%
Работать самостоятельно и не зависеть от других
Работать в команде и рассчитывать на помощь коллег
Организовывать и контролировать процесс работы

Быстрый ответ

Для того чтобы корректировать положение якоря и предотвратить его скрытие под фиксированным заголовком, можете применить создание псевдоэлемента при помощи CSS:

CSS
Скопировать код
.anchor::before {
  content: '';
  display: block;
  height: 0;
  margin-top: -100px; /* Высота вашего заголовка */
  padding-top: 100px; /* Значение, равное высоте заголовка */
  visibility: hidden;
  pointer-events: none;
}

Установите класс .anchor для элементов, которые выделены в качестве якорей. Отрицательное значение margin-top обеспечивает смещение на необходимую величину, а padding-top компенсирует его, давая возможность контенту под заголовком оставаться видимым при переходе по ссылке. Выставите значения margin-top и padding-top, согласованные с высотой вашего заголовка, чтобы корректно отобразить якорь.

Кинга Идем в IT: пошаговый план для смены профессии

Управление отзывчивостью и обеспечение кроссбраузерности

Отзывчивый дизайн: адаптация под изменения устройств

При разработке отзывчивого дизайна важно использовать относительные единицы, такие как em, для определения размеров заголовков и расчета требуемых смещений. Такой подход гарантирует однообразное отображение на разных устройствах, а также при различных настройках шрифтов.

CSS
Скопировать код
.anchor::before {
  margin-top: calc(-1 * var(--header-height)); /* Крайне рекомендуется хранить высоту заголовка в переменной CSS */
  padding-top: var(--header-height);
}

Для хранения значения высоты заголовка используйте переменную --header-height в корневом элементе CSS:

CSS
Скопировать код
:root {
  --header-height: 5em; /* Примерное значение, которое можно подменить на реальную высоту вашего заголовка */
}

Для адаптации смещения под размеры видимой области советуется динамически настроить эти величины при помощи JavaScript в сочетании с медиа-запросами, меняя значение --header-height.

Совместимость браузеров: обеспечение плавной навигации

Существуют свойства CSS scroll-margin-top и scroll-padding-top, поддерживаемые большинством современных браузеров. Все же, стоит выработать запасной вариант для устаревших браузеров. Ниже представлен пример кода на JavaScript, позволяющий корректно расчитать смещение:

JS
Скопировать код
window.addEventListener('hashchange', function() {
  var fixedHeaderHeight = document.querySelector('.fixed-header').offsetHeight;
  window.scrollTo(window.scrollX, window.scrollY – fixedHeaderHeight);
});

Высокоточное позиционирование

Управление точностью смещений и прозрачные разделители

Свойство scroll-padding-top позволяет точно контролировать расстояния прокрутки при переходе к якорю. Для достижения лучших результатов следует применять этот параметр в CSS.

CSS
Скопировать код
:root {
  scroll-padding-top: var(--header-height);
}

Визуальное смещение также можно улучшить при помощи прозрачного разделителя:

HTML
Скопировать код
<div class="spacer" style="height: 100px;"></div><!-- Высота, соответствующая вашему заголовку -->

Размещайте в верстке контейнеры-якоря с относительным позиционированием и отрицательным верхним отступом равным высоте заголовка:

HTML
Скопировать код
<div class="anchor-container" style="position: relative; top: -100px;"></div>

Визуализация

На веб-страницу можно взглянуть как на сцену фестивального концерта, где фиксированный заголовок играет роль крыши сцены. Без крыши у зрителей отличный обзор на исполнителя:

Markdown
Скопировать код
Зрители: [👩🎶, 👨🎤, 🧑🎸, 👩🎹]
Место назначения: 👨🎤

Но крыша предотвращает хороший вид:

Markdown
Скопировать код
🎪...👨🎤...? (Исполнитель скрыт за крышей)

В такой ситуации устанавливается "вышка наблюдения" (верхние поля):

Markdown
Скопировать код
🎪 + Вышка наблюдения (Поля): [👀🎶, 👀🎤, 👀🎸, 👀🎹]
Место назначения (Исполнитель): 👀🎤

Таким образом, даже с крышей сцены, исполнитель остается видимым для всех.

Точность при использовании семантического HTML и идентификаторов

Применяйте разным идентификаторам для якорей и сопоставите их соответствующим разделам сайта, основываясь на стилях CSS и обеспечивая точное направление навигации:

HTML
Скопировать код
<a href="#section1">Раздел 1</a>
...
<div id="section1-anchor" class="anchor"></div>
<section id="section1">Содержимое Раздела 1</section>

Структура HTML-документа, организованная в соответствии с принципами семантики, способствует лучшему порядку в документе, его доступности и решению проблемы перекрытия контента.

Умелое использование прокрутки

Контроль над точкой остановки и смещением

Свойство scroll-snap-type в CSS устанавливает точку остановки после прокрутки, упрощая навигацию.

Используйте это свойство вместе с JavaScript для создания эффекта плавного смещения, учитывая высоту фиксированного заголовка:

JS
Скопировать код
document.querySelector('.anchor').addEventListener('click', (e) => {
  e.preventDefault();
  let target = document.querySelector(e.target.getAttribute('href'));
  let headerOffset = document.querySelector('.fixed-header').offsetHeight;
  let elementPosition = target.offsetTop;
  window.scrollTo({
    top: elementPosition – headerOffset,
    behavior: 'smooth'
  });
});

Полезные материалы

  1. MDN Web Docs – Scroll Padding — документация по CSS-свойству scroll-padding-top, предназначенном для корректировки положения якорей.
  2. W3C CSS Scroll Snap Module — официальная спецификация от W3C на тему технологии прокрутки страницы.
  3. html – Перекрытие якорей фиксированным заголовком страницы – Stack Overflow — обсуждение проблемы перекрытия якорей в сообществе разработчиков с множеством предложенных решений.
  4. Scrollspy · Bootstrap — функционал Bootstrap для обновления ссылок навигации по мере прокрутки страницы.
  5. GitHub – scroll-into-view/scroll-into-view-if-needed — полифилл для более гибкого контроля над поведением прокрутки страницы.