Для позиционирования на экране различных устройств различных элементов 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-документа правильно и единообразно работают во всех современных браузеров как для настольных компьютеров, так и в мобильных устройствах.