Html display block vertical align

How to Vertically Center Inline (Inline-Block) Elements

There are many different techniques that you can use to align inline (inline-block) elements vertically. In this snippet, we’ll demonstrate some widely used solutions to this kind of alignment problem.

Solution with the CSS padding property

Sometimes inline (inline-block) elements can appear vertically centered due to the equal padding above and below them.

Example of vertically centering inline elements with the padding property:

html> html> head> title>Title of the document title> style> body < background: #c2c2c2; font-size: 90%; > main < background: #fff; margin: 20px 0; padding: 50px; > main a < background: #83d483; color: #fff; padding: 40px 30px; text-decoration: none; > style> head> body> main> a href="#0">1 a> a href="#0">2 a> a href="#0">3 a> main> body> html>

Result

Solution with the CSS line-height and height properties

Another way that can solve your problem with vertical alignment is setting the line-height property equal to the height. Use this method to center some text in the case if you are sure your text will not wrap.

Example of vertically centering an inline element with the line-height and height properties:

html> html> head> title>Title of the document title> style> body < background: #c2c2c2; font-size: 90%; > main < background: #fff; margin: 20px 0; padding: 40px; > main span < display: inline-block; background: #83d483; color: #fff; height: 100px; line-height: 100px; padding: 20px; width: 50%; white-space: nowrap; > style> head> body> main> span>Example of a vertically centered line. span> main> body> html>

Solution with the CSS vertical-align property

The CSS vertical-align property applies to the elements that are being aligned and not to their parent element.

Example of vertically centering inline and inline-block elements with the vertical-align property:

html> html> head> title>Title of the document title> style> div < background: #dbdbdb; margin: 10px; line-height: 100px; > div > * < vertical-align: middle; line-height: normal; > a < background-color: #83d483; height: 20px; display: inline-block; border: solid 1px #666; padding: 5px; > span < background: #6fa2bf; > style> head> body> div> a href="#">Some link a> span>Some text span> div> body> html>

Example of vertically centering the content inside

and elements:

html> html> head> title>Title of the document title> style> body < background: #c2c2c2; font-size: 90%; > table < background: #fff; width: 200px; border-collapse: separate; margin: 15px; height: 200px; > table td < background: #83d483; color: #fff; padding: 15px; border: 5px solid #fff; /* default is vertical-align: middle; */ > .center-table < display: table; height: 200px; background: #fff; width: 200px; margin: 20px; > .center-table p < display: table-cell; margin: 0; background: #83d483; color: #fff; padding: 20px; border: 5px solid #fff; vertical-align: middle; > style> head> body> table> tr> td>Example of vertically centered multiple lines of text in a table cell. td> tr> table> div class="center-table"> p>Example of vertically centered multiple lines of text in a CSS-created table layout. p> div> body> html>

Solution with the CSS Flexbox

Vertical alignment of inline elements is also possible with Flexbox. You can easily use a single flex-child to center it in a flex-parent.

Example of vertically centering inline elements with Flexbox:

html> html> head> title>Title of the document title> style> body < background: #c2c2c2; font-size: 90%; > div < background: #fff; width: 200px; margin: 20px; > .flex-center < background: #83d483; color: #fff; border: 5px solid #fff; display: flex; flex-direction: column; justify-content: center; height: 200px; resize: vertical; overflow: auto; > .flex-center span < margin: 0; padding: 15px; > style> head> body> div class="flex-center"> span>Example of vertically centered multiple lines in a flexbox container. span> div> body> html>

Solution with the “ghost element” technique

This technique assumes that a pseudo-element (in our example it’s :before) is given a full height. It is placed within the container, and the text is aligned with that. In the next example, we have a

element, which is a block-level element, but we make it inline-block by using the display property.

Example of vertically centering inline elements with a «ghost element»:

html> html> head> title>Title of the document title> style> body < background: #c2c2c2; font-size: 90%; > div < background: #fff; width: 240px; height: 200px; margin: 15px; color: #fff; resize: vertical; overflow: auto; padding: 20px; > .ghost-center < position: relative; > .ghost-center::before < content: " "; display: inline-block; height: 100%; width: 1%; vertical-align: middle; > .ghost-center p < display: inline-block; vertical-align: middle; width: 190px; margin: 0; padding: 10px; background: #83d483; > style> head> body> div class="ghost-center"> p>Example of vertically centered multiple lines in a container. p> div> body> html>

Источник

Все способы вертикального выравнивания в CSS

image

Я думаю, многие из вас, кому приходилось заниматься версткой, сталкивались с необходимостью выравнивать элементы по вертикали и знают, какие сложности возникают при выравнивании элемента по центру.

Да, для вертикального выравнивания в CSS есть специальное свойство vertical-align с множеством значений. Однако на практике оно работает совсем не так, как ожидается. Давайте попробуем в этом разобраться.

Сравним следующие подходы. Выравнивание с помощью:

  • таблицы,
  • отступов,
  • line-height ,
  • растягивания,
  • отрицательного margin ,
  • transform ,
  • псевдоэлемента,
  • flexbox .

image

Есть два элемента div , при этом один из них вложен в другой. Дадим им соответствующие классы − outer и inner .

Задача состоит в том, чтобы выровнять внутренний элемент по центру внешнего элемента.

Для начала рассмотрим случай, когда размеры внешнего и внутреннего блока известны. Добавим внутреннему элементу правило display: inline-block , а внешнему − text-align: center и vertical-align: middle .

Нпомню, что выравнивание применяется только к элементам, которые имеют режим отображения inline или inline-block .

Зададим блокам размеры, а также фоновые цвета, чтобы видеть их границы.

После применения стилей мы увидим, что внутренний блок выровнялся по горизонтали, а по вертикали нет:
http://jsfiddle.net/c1bgfffq/

Почему так произошло? Дело в том, что свойство vertical-align влияет на выравнивание самого элемента, а не его содержимого (кроме случаев, когда оно применяется к ячейкам таблицы). Поэтому применение данного свойства к внешнему элементу ничего не дало. Более того, применение этого свойства к внутреннему элементу также ничего не даст, поскольку строчные блоки ( inline-block ) выравниваются по вертикали относительно соседних блоков, а в нашем случае у нас один строчный блок.

Для решения данной проблемы существует несколько техник. Ниже подробнее рассмотрим каждую из них.

Выравнивание с помощью таблицы

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

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

Первый минус можно частично убрать, заменив теги table и td на div и задав табличный режим отображения в CSS.

Тем не менее внешний блок все равно останется таблицей со всеми вытекающими из этого последствиями.

Выравнивание с помощью отступов

Если высоты внутреннего и внешнего блока известны, то выравнивание можно задать с помощью вертикальных отступов у внутреннего блока, используя формулу: (Houter – Hinner) / 2.

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

Выравнивание с помощью line-height

Если известно, что внутренний блок должен занимать не более одной строки текста, то можно воспользоваться свойством line-height и задать его равным высоте внешнего блока. Поскольку контент внутреннего блока не должен переноситься на вторую строку, рекомендуется также добавить правила white-space: nowrap и overflow: hidden .

Также данную технику можно применять и для выравнивания многострочного текста, если для внутреннего блока переопределить значение line-height , а также добавить правила display: inline-block и vertical-align: middle .

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

Выравнивание с помощью «растягивания»

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

  1. задать внешнему блоку относительное позиционирование, а внутреннему − абсолютное;
  2. добавить внутреннему блоку правила top: 0 и bottom: 0 , в результате чего он растянется на всю высоту внешнего блока;
  3. установить значение auto для вертикальных отступов внутреннего блока.

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

Минус данного способа — должна быть известна высота внутреннего блока.

Выравнивание с помощью отрицательного margin-top

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

Нужно задать внешнему блоку относительное позиционирование, а внутреннему − абсолютное. Затем необходимо сдвинуть внутренний блок вниз на половину высоты внешнего блока top: 50% и поднять вверх на половину собственной высоты margin-top : -Hinner / 2.

Минус данного способа — должна быть известна высота внутреннего блока.

Выравнивание с помощью transform

Данный способ похож на предыдущий, но он может быть применен, когда высота внутреннего блока неизвестна. В этом случае вместо задания отрицательного отступа в пикселях можно воспользоваться свойством transform и поднять внутренний блок вверх с помощью функции translateY и значения -50% .

Почему в предыдущем способе нельзя было задать значение в процентах? Так как процентные значения свойства margin вычисляются относительно родительского элемента, значение в 50% равнялось бы половине высоты внешнего блока, а нам нужно было поднять внутренний блок на половину его собственной высоты. Для этого как раз подходит свойство transform .

Минус данного способа в ограниченной поддержке свойства transform старыми версиями браузера IE.

Выравнивание с помощью псевдоэлемента

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

Суть способа в добавлении внутри внешнего блока строчного блока inline-block высотой в 100% и задания ему вертикального выравнивания. В этом случае высота добавленного блока будет равна высоте внешнего блока. Внутренний блок выровняется по вертикали относительно добавленного, а значит, и внешнего блока.

Чтобы не нарушать семантику, строчный блок рекомендуется добавить с помощью псевдоэлемента before или after .

Минус данного способа — он не может быть применен, если внутренний блок имеет абсолютное позиционирование.

Выравнивание с помощью Flexbox

Самый современный способ вертикального выравнивания это использовать Flexible Box Layout (в народе известен как Flexbox ). Данный модуль позволяет гибко управлять позиционированием элементов на странице, располагая их практически как угодно. Выравнивание по центру для Flexbox − очень простая задача.

Внешнему блоку необходимо задать display: flex , а внутреннему − margin: auto . И это все! Красиво, правда?

Минус данного способа − Flexbox поддерживается только современными браузерами.

Какой способ выбрать?

Нужно исходить из постановки задачи:

  • Для вертикального выравнивания текста лучше использовать вертикальные отступы или свойство line-height .
  • Для абсолютно позиционированных элементов с известной высотой (например, иконок) идеально подойдет способ с отрицательным свойством margin-top .
  • Для более сложных случаев, когда неизвестна высота блока, нужно использовать псевдоэлемент или свойство transform .
  • Ну а если вам повезло настолько, что не нужно поддерживать старые версии браузера IE, то, конечно, лучше использовать Flexbox .

Источник

Читайте также:  font-weight
Оцените статью