Центрированное позиционирование div на прокручиваемой странице

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

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

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

Для того чтобы 'div' оставался полноценно зафиксированным в середине экрана, обратитесь к следующему CSS коду: position: fixed;, top: 50%;, left: 50%; и transform: translate(-50%, -50%);. Это обеспечит устойчивое размещение элемента в середине экрана, даже при прокрутке страницы.

CSS
Скопировать код
.fixed-center {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

Назначение вашему div класса .fixed-center, а также определение ширины и высоты элемента обеспечит идеальное центрирование.

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

Управление затруднительными и сложными сценариями

В процессе центрирования могут возникнуть нестандартные задачи, для которых необходим особый подход. Исследуйте несколько методов их решения.

Когда размер содержимого не фиксирован

Если размер 'div' может меняться, то фиксированные значения ширины и высоты не эффективны. В таких случаях следует использовать свойство transform:

CSS
Скопировать код
.dynamic-center {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

Это свойство позволит элементу сохранять центрирование, несмотря на изменение его размеров.

Подробнее об этом расскажет наш спикер на видео
skypro youtube speaker

Удержание 'div' на верхуем уровне слоев

Вам может потребоваться, чтобы центральный div всегда был виден впереди остального контента. Увеличение z-index поможет в достижении желаемого результата:

CSS
Скопировать код
.layered-center {
  position: fixed;
  z-index: 100;
}

Обязательно следите, чтобы значение z-index не конфликтовало со значениями других элементов.

Добавление прозрачного фонового оверлея

В некоторых случаях, например при создании модальных окон или подсветке элементов, требуется затмение остальной части страницы:

HTML
Скопировать код
<div class="overlay">
  <div class="fixed-center">
    <!-- Центральный контент тут -->
  </div>
</div>

Стилизация overlay с использованием прозрачности или цвета помогает создать необходимое настроение.

Отзывчивость для фиксированных элементов

Фиксированные элементы на маленьких устройствах могут быть неудобны. Отзывчивый дизайн помогает обойти эти ограничения.

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

Давайте мысленно представим ваш div как символический забор в пейзаже, который остается неизменным, независимо от прокрутки:

Markdown
Скопировать код
Ландшафт с прокруткой: [Прокручиваем вверх, Центр экрана, Прокручиваем вниз]
CSS
Скопировать код
.picket-fence {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

Поэтому забор всегда уверенно сохраняет свою позицию:

Markdown
Скопировать код
При прокрутке: [🛤️, 🖼️👁️, 🛣️]
- Он остаётся на месте.

Дальнейшее погружение в техники центрирования

Отступы: секретный инструмент точности

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

CSS
Скопировать код
.margin-center {
  margin-left: -width / 2;
  margin-top: -height / 2;
}

Приемы с использованием контейнеров

Для контроля над непредсказуемым содержимым, рекомендуется поместить 'div' внутрь родительского контейнера:

CSS
Скопировать код
.container {
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  inset: 0;
}

Адаптивность — ваш ключ к успеху

Чтобы 'div' выглядел отлично на любом экране, обязательно применяйте медиа-запросы.

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

  1. Полное руководство по центрированию в CSS на сайте CSS-Tricks.
  2. Инструкции по центрированию элементов от MDN.
  3. Как горизонтально и вертикально центрировать элемент в CSS – материалы W3Schools.
  4. Основы позиционирования в CSS от A List Apart.
  5. Полное руководство по Flexbox от CSS-Tricks.
  6. Горизонтальное и вертикальное центрирование 'div' с примерами на Stack Overflow.
  7. Примеры вертикального и горизонтального центрирования 'div' на CodePen.
Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей
Какой CSS код позволяет центровать div, фиксируя его в середине экрана?
1 / 5