Выравнивание и равное распределение div/span в CSS

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

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

Для горизонтального выравнивания элементов используйте CSS Flexbox. Назначьте родительскому контейнеру свойство display: flex; и его потомки (span или div) автоматически выстроятся в одну линию.

CSS
Скопировать код
.container { display: flex; }  /* Просто, чисто и элегантно. */
HTML
Скопировать код
<div class="container">
  <div>Первый</div>  /* Берет на себя инициативу. */
  <div>Второй</div>  /* Занимает центральное положение. */
  <div>Третий</div>  /* Завершает шествие. */
</div>

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

Пригодится свойство display

Выберите способ расположения элементов с помощью свойства display. Кроме flexbox, что подходит для большинства случаев, может пригодиться inline-block или grid, когда дизайн предусматривает определённые особенности.

Inline-block

CSS
Скопировать код
div {
  display: inline-block; /* Выстраиваемся в лестницу, сохраняя при этом блочные характеристики. */
}

Вспомните о отступах и проблемах, связанных с дополнительными пробелами между элементами HTML, при использовании inline-block.

CSS Grid

Если нужно учесть идиосинкразии дизайна, CSS Grid придет к вам на помощь. Эта технология обеспечивает точное выравнивание благодаря мощным инструментам, таким как grid-template-columns и column-gap.

CSS
Скопировать код
.container {
  display: grid;  /* Сетка в действии! */
  grid-template-columns: repeat(3, 1fr);
  column-gap: 10px; /* Каждый элемент получает немного свободного пространства. */
}

Выравнивание элементов с использованием Flexbox

Flexbox предлагает больше, чем просто последовательное размещение. С помощью свойств justify-content и align-items можно достигнуть идеального расположения элементов.

Распределение на равные интервалы

justify-content разместит элементы на одинаковом расстоянии друг от друга:

CSS
Скопировать код
.container {
  display: flex;
  justify-content: space-between;  /* Как жизненное пространство, так необходимое каждому. */
}

Вертикальное центрирование

Для вертикального центрирования элеметов используйте align-items:

CSS
Скопировать код
.container {
  display: flex;
  align-items: center; /* Йога для div'ов. Найдите свою средину. */
}

Реализация адаптивности при помощи медиазапросов

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

CSS
Скопировать код
@media (max-width: 768px) {
  .container {
    flex-direction: column; /* Располагаемся в колонку – эффективный подход для мобильных устройств. */
  }
}

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

Понять принцип выравнивания элементов span или div можно, представив себе поезд на рельсах:

Markdown
Скопировать код
🛤️ Железнодорожные пути: --------------------------------

🚂 # Вагоны (span/div):

<span>🚃</span> <span>🚃</span> <span>🚃</span>

Display:  |🚃| Вместо:    |🚃|
          |🚃|            |🚃|
          |🚃|            |🚃|

Управляйте положением элементов (div, span) в одном ряду, используя:

CSS
Скопировать код
span {
  display: inline-block; /* Либо выстраиваем их в одну линию с помощью float: left. */
  /* или */
  float: left;
}

Теперь ваши элементы на пути к успеху! 🚃🚃🚃

Управление хаосом: очистка от float'ов

Не дайте элементам с float навести хаос, используйте Clearfix hack, чтобы взять ситуацию под контроль.

CSS
Скопировать код
.clearfix::after {
  content: "";  /* Все следы исчезли. */
  clear: both; /* Буянам-`float`ам показано их место. */
  display: table;
}

Однако, если ваша верстка регулируется flexbox или grid, использование clear: both; не требуется.

CSS фреймворки и возникающие конфликты

Применение фреймворка, например Bootstrap, может облегчить выравнивание за счет предустановленных классов, таких как .d-flex или .row. Однако будьте осторожны: конфликты в CSS могут вызвать проблемы с отображением ваших элементов.

Совместимость с браузерами

Проверьте работу в различных браузерах, чтобы убедиться в корректности отображения. Если возникают проблемы, не забывайте о запасных вариантах.

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

  1. Полное руководство по Flexbox от CSS-Tricks – Ознакомьтесь со всеми аспектами flexbox.
  2. Основные концепции Flexbox с MDN — Начните с базовых принципов.
  3. Центрирование в CSS: полное руководство от CSS-Tricks — Изучите различные методы центрирования.
  4. Flexbox Froggy – игра для учебы CSS flexbox — Овладейте flexbox играючи.
  5. Flexbox в глоссарии MDN Web Docs — Конспект по свойствам flexbox.
  6. Сетка CSS на MDN — Ознакомьтесь с возможностями CSS Grid.
  7. Визуальное руководство по свойствам Flexbox от DigitalOcean — Наглядное пособие по свойствам flexbox.