Для позиционирования на экране различных устройств различных элементов HTML-документа применяются разные HTML-теги. Однако, стандартная разметка HTML не всегда подходит для правильного отображения того или иного элемента с точки зрения дизайна. Для того, чтобы правильно разместить тот или иной элемент иногда требуется поменять его стандартное поведение в массиве других, окружающих его документов. Для этих целей удобнее всего задать (или переопределить) CSS свойство display
, которое определяет, как элемент должен быть показан в документе. В этой статье рассмотрим, какие значения может принимать свойство display
и как это скажется на свойствах и поведении того, объекта, к которому это свойство применяется.
Значения CSS свойства display
для элементов HTML-документа
block
- Элемент показывается как блочный. Применение этого значения для строчных элементов, например
<span>
, заставляет его вести подобно блокам — происходит перенос строк в начале и в конце содержимого.
- Элемент показывается как блочный. Применение этого значения для строчных элементов, например
inline
- Элемент отображается как строчный. Использование блочных элементов, таких, как
<p>
и<div>
, автоматически создаёт перенос и показывает их содержимое с новой строки. Значениеinline
отменяет эту особенность, поэтому содержимое блочных элементов начинается с того места, где окончился предыдущий элемент.
- Элемент отображается как строчный. Использование блочных элементов, таких, как
inline-block
- Это значение генерирует блочный элемент, который обтекается другими элементами веб-страницы подобно строчному элементу. Фактически такой элемент по своему действию похож на встраиваемые элементы (вроде
<img>
). При этом его внутренняя часть форматируется как блочный элемент, а сам элемент — как строчный.
- Это значение генерирует блочный элемент, который обтекается другими элементами веб-страницы подобно строчному элементу. Фактически такой элемент по своему действию похож на встраиваемые элементы (вроде
inline-table
- Определяет, что элемент является таблицей, как при использовании
<table>
, но при этом таблица является строчным элементом и происходит её обтекание другими элементами, например, текстом.
- Определяет, что элемент является таблицей, как при использовании
inline-flex
- Элемент ведёт себя как строчный и выкладывает содержимое согласно флекс-модели.
flex
- Элемент ведёт себя как блочный и выкладывает содержимое согласно флекс-модели.
list-item
- Элемент выводится как блочный и добавляется маркер списка.
none
- Временно удаляет элемент из документа. Занимаемое им место не резервируется, и веб-страница формируется так, словно элемента и не было. Изменить значение и сделать вновь видимым элемент можно с помощью скриптов, обращаясь к свойствам через объектную модель (см.ниже). В этом случае происходит переформатирование данных на странице с учётом вновь добавленного элемента.
run-in
- Устанавливает элемент как блочный или строчный, в зависимости от контекста.
table
- Определяет, что элемент является блочной таблицей, подобно использованию
<table>
.
- Определяет, что элемент является блочной таблицей, подобно использованию
table-caption
- Задаёт заголовок таблицы, подобно применению
<caption>
.
- Задаёт заголовок таблицы, подобно применению
table-cell
- Указывает, что элемент представляет собой ячейку таблицы (
<td>
или<th>
).
- Указывает, что элемент представляет собой ячейку таблицы (
table-column
- Назначает элемент колонкой таблицы, словно был добавлен
<col>
.
- Назначает элемент колонкой таблицы, словно был добавлен
table-column-group
- Определяет, что элемент является группой одной или более колонок таблицы, как при использовании
<colgroup>
.
- Определяет, что элемент является группой одной или более колонок таблицы, как при использовании
table-footer-group
- Используется для хранения одной или нескольких строк ячеек, которые отображаются в самом низу таблицы. По своему действию сходно с работой
<tfoot>
.
- Используется для хранения одной или нескольких строк ячеек, которые отображаются в самом низу таблицы. По своему действию сходно с работой
table-header-group
- Элемент предназначен для хранения одной или нескольких строк ячеек, которые представлены вверху таблицы. По своему действию сходно с работой
<thead>
.
- Элемент предназначен для хранения одной или нескольких строк ячеек, которые представлены вверху таблицы. По своему действию сходно с работой
table-row
- Элемент отображается как строка таблицы
<tr>
.
- Элемент отображается как строка таблицы
- table-row-group
- Создаёт структурный блок, состоящий из нескольких строк таблицы, аналогично действию
<tbody>
.
- Создаёт структурный блок, состоящий из нескольких строк таблицы, аналогично действию
Объектная модель CSS свойства display
для элементов HTML-документа
Для доступа к уже установленному CSS свойству display
выбранного элемента (объекта) HTML-документа можно воспользоваться его объектной моделью и с помощью JavaScript переопределить его значение на странице уже в собранном (отображённом) на экране документе. На этом основана работа большинства алгоритмов открытия/закрытия всплывающих окон, когда по определённым событиям (кликам) свойство требуемого объекта (всплывающего окна) меняется со значения display: block;
на display: none;
и обратно. Доступ к свойству display
выбранного элемента (объекта) HTML-документа происходит с помощью изменения свойств в следующем объекте:
Объект.style.display
Резюме
Большинство описанных выше CSS свойств display
для элементов HTML-документа правильно и единообразно работают во всех современных браузеров как для настольных компьютеров, так и в мобильных устройствах.
Заберите ссылку на статью к себе, чтобы потом легко её найти!
Раз уж досюда дочитали, то может может есть желание рассказать об этом месте своим друзьям, знакомым и просто мимо проходящим?
Не надо себя сдерживать! ;)