- PVSM.RU - https://www.pvsm.ru -

К сожалению, не у всех есть браузер/устройство, поддерживающие flexbox. Это руководство в виде шпаргалки, в котором предлагаются альтернативы обратной совместимости для свойств flexbox.
Хотя некоторый CSS-код в этом руководстве, возможно, покажется очевидным, я собираюсь бросить вызов flexbox, а также предложить простые решения проблем, которые возникали, пока он не обрёл популярность.
Отображает элементы горизонтально
.item {
display: inline-block;
}
Отображает элементы горизонтально в обратном порядке
.container {
direction: rtl;
}
.item {
display: inline-block;
}
Отображает элементы вертикально
.item {
display: block;
}

Отображает элементы вертикально в обратном порядке
.container, .item {
transform: scaleY(-1);
-ms-transform: scaleY(-1);
-webkit-transform: scaleY(-1);
}
.item {
display: block;
}
Сужает элементы для предотвращения переноса
.container {
display: table;
}
.item {
display: table-cell;
}

Переносит элементы на другую строку, когда их общая ширина больше ширины контейнера
.item {
display: inline-block;
}
Выравнивает элементы по горизонтали в начале контейнера
.item {
display: inline-block;
}

Выравнивает элементы по горизонтали в конце контейнера
.container {
text-align: right;
}
.item {
display: inline-block;
}

Выравнивает элементы по горизонтали по центру контейнера
.container {
text-align: center;
}
.item {
display: inline-block;
}

Распределяет равное пространство между элементами, заставляя крайние элементы прижаться к краям контейнера
.container {
text-align: justify;
}
.container:after {
content: '';
display: inline-block;
width: 100%;
}
.item {
display: inline-block;
}

Примечание: этот метод работает только с несжатым HTML и требует фиксированную высоту у контейнера.
Равномеро распределяет пространство между элементами
.container {
display: table;
}
.item {
display: table-cell;
text-align: center;
}

Выравнивает элементы по вертикали в начале контейнера
.item {
display: table-cell;
}
Выравнивает элементы по вертикали в конце контейнера
.container {
display: table;
}
.item {
display: table-cell;
vertical-align: bottom;
}
Выравнивает элементы по вертикали в центру контейнера
.container {
display: table;
}
.item {
display: table-cell;
vertical-align: middle;
}

Растягивает элементы по вертикали от начала до конца контейнера
.item {
display: inline-block;
height: 100%;
}
Выравнивает элементы по вертикали в начале контейнера
.item {
display: inline-block;
}
Выравнивает элементы по вертикали в конце контейнера
.container {
display: table-cell;
vertical-align: bottom;
}
.item {
display: inline-block;
}

Выравнивает элементы по вертикали по центру контейнера
.container {
display: table-cell;
vertical-align: middle;
}
.item {
display: inline-block;
}
Растягивает элемент, чтобы заполнить оставшееся пространство
.container {
display: table;
}
.item {
display: table-cell;
}
.item.grow {
width: 100%;
}
Сужает элемент, а другие элементы заполняют оставшееся пространство
.container {
display: table;
}
.item {
display: table-cell;
}
.item.shrink {
width: 1px;
}

Автор: psywalker
Источник [25]
Сайт-источник PVSM.RU: https://www.pvsm.ru
Путь до страницы источника: https://www.pvsm.ru/html/117461
Ссылки в тексте:
[1] flex-direction: #flex-direction
[2] flex-wrap: #flex-wrap
[3] justify-content: #justify-content
[4] align-items: #align-items
[5] align-content: #align-content
[6] flex items: #flex-items
[7] Ссылка на живой пример.: http://codepen.io/psywalker/pen/xVpQmG
[8] Ссылка на живой пример.: http://codepen.io/psywalker/pen/MyrzdR
[9] Ссылка на живой пример.: http://codepen.io/psywalker/pen/LNeMYb
[10] Ссылка на живой пример.: http://codepen.io/psywalker/pen/KzZbKE
[11] Ссылка на живой пример.: http://codepen.io/psywalker/pen/XdVoed?editors=1100
[12] Ссылка на живой пример.: http://codepen.io/psywalker/pen/yOpGRY?editors=1100
[13] Ссылка на живой пример.: http://codepen.io/psywalker/pen/eZybQd?editors=1100
[14] Ссылка на живой пример.: http://codepen.io/psywalker/pen/JXMwxr?editors=1100
[15] Ссылка на живой пример.: http://codepen.io/psywalker/pen/wGpRZL?editors=1100
[16] Ссылка на живой пример.: http://codepen.io/psywalker/pen/groZVE?editors=1100
[17] Ссылка на живой пример.: http://codepen.io/psywalker/pen/wGpNBw?editors=1100
[18] Ссылка на живой пример.: http://codepen.io/psywalker/pen/YqYBPJ?editors=1100
[19] Ссылка на живой пример.: http://codepen.io/psywalker/pen/ZWvwGL?editors=1100
[20] Ссылка на живой пример.: http://codepen.io/psywalker/pen/aNEXvE?editors=1100
[21] Ссылка на живой пример.: http://codepen.io/psywalker/pen/aNEXdE?editors=1100
[22] Ссылка на живой пример.: http://codepen.io/psywalker/pen/KzZJzM?editors=1100
[23] Ссылка на живой пример.: http://codepen.io/psywalker/pen/BKJMzB?editors=1100
[24] Ссылка на живой пример.: http://codepen.io/psywalker/pen/ONzdbL?editors=1100
[25] Источник: https://habrahabr.ru/post/281254/
Нажмите здесь для печати.