- CSS Layout — display: inline-block
- Example
- Using inline-block to Create Navigation Links
- Example
- Grid of Boxes
- Examples
- Example
- Example
- border — block
- Пример
- Как понять
- Как пишется
- Подсказки
- Рамки и границы
- Свойство outline
- Разноцветные рамки
- Рамка при использовании :hover
- Рамка вокруг полей формы
- Рамки через box-shadow
CSS Layout — display: inline-block
Compared to display: inline , the major difference is that display: inline-block allows to set a width and height on the element.
Also, with display: inline-block , the top and bottom margins/paddings are respected, but with display: inline they are not.
Compared to display: block , the major difference is that display: inline-block does not add a line-break after the element, so the element can sit next to other elements.
The following example shows the different behavior of display: inline , display: inline-block and display: block :
Example
span.a <
display: inline; /* the default for span */
width: 100px;
height: 100px;
padding: 5px;
border: 1px solid blue;
background-color: yellow;
>
span.b display: inline-block;
width: 100px;
height: 100px;
padding: 5px;
border: 1px solid blue;
background-color: yellow;
>
span.c display: block;
width: 100px;
height: 100px;
padding: 5px;
border: 1px solid blue;
background-color: yellow;
>
Using inline-block to Create Navigation Links
One common use for display: inline-block is to display list items horizontally instead of vertically. The following example creates horizontal navigation links:
Example
.nav <
background-color: yellow;
list-style-type: none;
text-align: center;
padding: 0;
margin: 0;
>
.nav li display: inline-block;
font-size: 20px;
padding: 20px;
>
Grid of Boxes
It has been possible for a long time to create a grid of boxes that fills the browser width and wraps nicely (when the browser is resized), by using the float property.
However, the inline-block value of the display property can make this easier (but it is not flawless — see more examples below).
Examples
Floating boxes — using float (notice that we also need to specify a clear property for the element after the floating boxes):
Example
.floating-box <
float: left;
width: 150px;
height: 75px;
margin: 10px;
border: 3px solid #73AD21;
>
The same effect can be achieved by using the inline-block value of the display property (notice that no clear is needed):
Example
.floating-box <
display: inline-block;
width: 150px;
height: 75px;
margin: 10px;
border: 3px solid #73AD21;
>
border — block
border — block — это логическое свойство-шорткат. Он создаёт у элемента рамки по блочной оси.
Блочная ось связана с направлением потока сайта. Например, для русского и английского языков border — block рисует границу сверху и снизу элемента (поток идёт сверху вниз), а для японского справа и слева (поток идёт справа налево).
Пример
Скопировать ссылку «Пример» Скопировано
div border-block: 5px solid white;>
div border-block: 5px solid white; >
Как понять
Скопировать ссылку «Как понять» Скопировано
С помощью border — block граница нарисуется всегда там, где нужно, вне зависимости от языка 😎
Допустим, мы хотим выделить текст сверху и снизу аккуратными границами. Попробуем сделать это с помощью свойств border — top и border — bottom :
div border-top: 7px dashed white; border-bottom: 7px dashed white;>
div border-top: 7px dashed white; border-bottom: 7px dashed white; >
А теперь текст будет на японском языке, для этого сменим поток и посмотрим, что будет:
div writing-mode: vertical-rl;>
div writing-mode: vertical-rl; >
Язык другой, направление письма другое, а границы всё там же — сверху и снизу. Теперь используем правильное свойство border — block и снова понаблюдаем:
div writing-mode: vertical-rl; border-block: 7px dashed white;>
div writing-mode: vertical-rl; border-block: 7px dashed white; >
Сейчас всё логично: стиль письма справа налево, и граница справа и слева текста, как мы и хотели. border — block обо всём позаботился!
японское «鯖» из примеров переводится как «скумбрия».
Как пишется
Скопировать ссылку «Как пишется» Скопировано
border — block пишется так же, как и border , а ещё сокращает такие же свойства. Отличие лишь в том, что border в записи заменяется на border — block :
- border — block — width — ширина границы;
- border — block — style — стиль границы;
- border — block — color — цвет границы.
Можно отдельно стилизовать одну из границ по аналогии с border — top и border — bottom :
- border — block — start — первая граница по направлению блочной оси;
- border — block — end — вторая граница.
Подсказки
Скопировать ссылку «Подсказки» Скопировано
💡 Когда нужно, чтобы видимые границы блока разместились в противоположном блочной оси направлении, используйте свойство border — inline , — оно рисует видимые границы по направлению строчной оси.
div border-inline: 5px solid white;>
div border-inline: 5px solid white; >
Рамки и границы
С помощью CSS можно добавить рамку к элементу несколькими способами. В основном, конечно же, применяется свойство border , как наиболее универсальное, а также outline и, как ни удивительно, box-shadow , основная задача которого — создание тени. Далее рассмотрим эти методы и их различия между собой.
Свойство outline
Самое простое свойство для создания рамок. Имеет те же параметры, что и border , но существенно отличается от него некоторыми деталями:
- outline выводится вокруг элемента ( border внутри);
- outline не влияет на размеры элемента ( border добавляется к ширине и высоте элемента);
- outline можно установить только вокруг элемента целиком, но никак не на отдельных сторонах ( border можно использовать для любой стороны или всех сразу);
- на outline не действует радиус скругления, заданный свойством border-radius (на border действует).
Возникает вопрос — в каких случаях нужен outline , когда его роль, несмотря на перечисленные отличия, вполне берёт на себя border ? Ситуаций не так и много, но они встречаются:
- создание сложных разноцветных рамок;
- добавление рамки к элементу при наведении на него курсора мыши;
- сокрытие рамки, добавляемой браузером автоматически для некоторых элементов при получении фокуса;
- для outline можно задать расстояние от края элемента до рамки с помощью свойства outline-offset , для создания различных дизайнерских эффектов.
Разноцветные рамки
Надо понимать, что outline ни в коей мере не заменяет border и вполне может существовать вместе с ним, как показано в примере 1.
В данном примере вокруг элемента добавляется чёрная рамка, которая отделена от фона белой каймой (рис. 1).
Рис. 1. Рамка вокруг элемента
Рамка при использовании :hover
При добавлении рамки через border происходит увеличение ширины элемента, что довольно заметно при сочетании border и псевдокласса :hover . Есть два способа, как это «победить». Самое простое — заменить border на outline , которое, как мы знаем, не оказывает влияния на размеры элемента (пример 2).
Пример 2. Рамка при наведении
outline не всегда годится, хотя бы потому, что на него скругление уголков не действует. Здесь подойдёт второй метод — добавляем невидимую рамку или рамку, совпадающую с цветом фона, а затем меняем её параметры при наведении (пример 3). Тогда никакого смещения элемента происходить не будет, поскольку рамка изначально уже есть. Но всегда помним, что ширина элемента при этом складывается из значений width , border слева и border справа. Аналогично обстоит и с высотой.
Пример 3. Рамка при наведении
Рамка вокруг полей формы
В некоторых браузерах (Chrome, Safari, последние версии Opera) вокруг полей формы при получении ими фокуса отображается небольшая цветная рамка (рис. 2). Чтобы её убрать, достаточно в стилях добавить к свойству outline значение none , как показано в примере 4.
Рамки через box-shadow
Хотя свойство box-shadow предназначено для добавления тени вокруг элемента, с его помощью можно и создавать рамки, причём такие, которые невозможно сделать через border или outline . Всё благодаря тому, что число теней может быть неограниченным, параметры которых перечисляются через запятую.
Чтобы получить рамку, первые три параметра следует задать нулевыми, они отвечают за положение тени и её размытие. Четвёртый параметр в данном случае отвечает за толщину границы, а пятый устанавливает цвет рамки. Для второй рамки четвёртый параметр равняется сумме толщин двух рамок.
В примере 4 показано добавление двух рамок и одной границы справа с помощью одного свойства box-shadow .
Пример 4. Использование box-shadow
Результат данного примера показан на рис. 3.
Рис. 3. Рамки, созданные свойством box-shadow