какая высота будет у блока описываемого в коде ниже

Блочная модель

какая высота будет у блока описываемого в коде ниже. 3 01. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 01. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 01. Рис. 3.1. Свойства, формирующие блочный элемент

Рис. 3.1. Свойства, формирующие блочный элемент

Для наглядности свойства блока можно представить в виде матрёшек (рис. 3.2). Любую маленькую матрёшку можно вставить в более крупную матрёшку, но никак не наоборот.

какая высота будет у блока описываемого в коде ниже. 3 02. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 02. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 02. Рис. 3.1. Свойства, формирующие блочный элемент

Полем будем называть расстояние от внутреннего края границы или края блока до воображаемого прямоугольника, ограничивающего содержимое блока. Из-за того, что значения полей могут различаться на каждой стороне, применяют выражения «верхнее поле» или «поле сверху», и им подобные для других сторон. Обозначение «поля» следует понимать как одинаковое значение полей для всех сторон. Основное предназначение полей — создать пустое пространство вокруг содержимого блочного элемента, например текста, чтобы он не прилегал плотно к краю элемента. Использование полей повышает читабельность текста и улучшает внешний вид страницы. В примере 3.1 показано использование полей для оформления текста.

Пример 3.1.Использование свойства padding

XHTML 1.0 CSS 2.1 IE Cr Op Sa Fx

Результат примера показан на рис. 3.3.

какая высота будет у блока описываемого в коде ниже. 3 03. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 03. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 03. Рис. 3.1. Свойства, формирующие блочный элемент

Рис. 3.3. Поля вокруг текста

Значения полей не могут быть отрицательными.

Границы

Пример 3.2. Красная пунктирная линия

XHTML 1.0 CSS 2.1 IE Cr Op Sa Fx

Результат данного примера показан на рис. 3.4.

какая высота будет у блока описываемого в коде ниже. 3 04. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 04. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 04. Рис. 3.1. Свойства, формирующие блочный элемент

Рис. 3.4. Линия возле текста

Отступы

Отступом будем называть пустое пространство от внешнего края границы, полей или содержимого блока. Как уже упоминалось, границы с полями не обязательны и могут отсутствовать, так что способ формирования отступов зависит от ситуации. Как и в случае с полями, применяют выражения «верхний отступ» или «отступ сверху», и им подобные для других сторон. Обозначение «отступы» следует понимать как одинаковое значение отступов для всех сторон.

Для отступов характерны следующие особенности.

В примере 3.3 показано схлопывание отступов и их прозрачность.

Пример 3.3. Использование отступов

XHTML 1.0 CSS 2.1 IE Cr Op Sa Fx

Результат данного примера показан на рис. 3.5. Обратите внимание, что расстояние между блоками равно 20 пикселов, а не 40, которые получаются суммированием верхнего и нижнего отступа у блоков. Это происходит за счёт эффекта схлопывания, при котором близлежащие отступы объединяются.

какая высота будет у блока описываемого в коде ниже. 3 05. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 05. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 05. Рис. 3.1. Свойства, формирующие блочный элемент

Рис. 3.5. Отступы в элементе

Ширина блока

Ширина блока это комплексная величина и складывается из нескольких значений свойств:

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

какая высота будет у блока описываемого в коде ниже. 3 06. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 06. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 06. Рис. 3.1. Свойства, формирующие блочный элемент

Рис. 3.6. Ширина блока

Допустим, для слоя написан следующий стиль.

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

Ширина = 300 + 7 + 7 + 4 + 4 + 10 + 10 = 342

Надо отметить, что блочная модель с формированием ширины несет в себе кучу неудобств. Постоянно приходится заниматься вычислениями, когда требуется задать определенную ширину блока. Также начинаются проблемы при сочетании разных единиц измерения, в частности, процентов и пикселов. Предположим, что ширина контента задана как 90%, если сюда приплюсовать поля и границы, заданные в пикселах, то нельзя вычислить суммарную ширину блока, поскольку проценты напрямую в пикселы не переводятся (в CSS3 так суммировать можно, только поддерживается эта возможность далеко не всеми браузерами). В итоге может получиться так, что общая ширина блока превысит ширину веб-страницы, что приведёт к появлению горизонтальной полосы прокрутки. Выходов из подобной ситуации два — поменять алгоритм блочной модели и воспользоваться вложенными слоями.

Алгоритм блочной модели

Табл. 3.1. Поддержка браузерами свойства box-sizing

БраузерInternet ExplorerChromeOperaSafariFirefox
Версия8.0+2.0+7.0+3.0+1.0+
Свойствоbox-sizing-webkit-box-sizingbox-sizing-webkit-box-sizing-moz-box-sizing

Как видно из таблицы, в свойствах разброд и шатание, поэтому придется делать гибрид и указывать все три свойства одновременно (пример 3.4).

Пример 3.4. Ширина блока

XHTML 1.0 CSS 3 IE 7 IE 8+ Cr Op Sa Fx

Вложенные слои

Использование свойства box-sizing всем хорошо, кроме того, что не работает в старых версиях IE. Если вы верстаете сайт с учетом IE7 и IE6, вам подойдёт старый проверенный метод с вложением слоев. Идея простая — для внешнего блочного элемента задаётся только необходимая ширина, а для вложенного блока всё остальное — поля, границы и отступы. Поскольку по умолчанию ширина блока равна доступной ширине родителя, получится, что блоки в каком-то смысле накладываются друг на друга, при этом фактическая ширина такого комбинированного элемента будет чётко задана. В примере 3.5 показано использование вложенных слоев.

Пример 3.5. Вложенные слои

XHTML 1.0 CSS 2.1 IE Cr Op Sa Fx

Результат данного примера показан на рис. 3.7.

какая высота будет у блока описываемого в коде ниже. 3 07. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 07. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 07. Рис. 3.1. Свойства, формирующие блочный элемент

Рис. 3.7. Ширина блока в процентах

Преимуществом вложенных слоев является использование отступов ( box-sizing их не учитывает), универсальность метода, также то, что фон по желанию можно добавлять к одному или другому слою. Тем самым несколько меняется внешний вид элементов, это особенно актуально при включении фоновых рисунков. Из недостатков метода можно отметить добавление дополнительного блока, который усложняет структуру кода, особенно при частом применении метода. Но это можно считать мелочью по сравнению с преимуществами.

Высота блока

какая высота будет у блока описываемого в коде ниже. 3 08. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 08. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 08. Рис. 3.1. Свойства, формирующие блочный элемент

Рис. 3.8. Высота блока

Пример 3.6. Высота блока

XHTML 1.0 CSS 2.1 IE Cr Op Sa Fx

Результат данного примера показан на рис. 3.9.

какая высота будет у блока описываемого в коде ниже. 3 09. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 09. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 09. Рис. 3.1. Свойства, формирующие блочный элемент

Рис. 3.9. Высота блока в процентах

С высотой связана ещё одна особенность — при превышении содержимого блока его размеров при заданной высоте, содержимое начинается отображаться поверх блока (рис. 3.10).

какая высота будет у блока описываемого в коде ниже. 3 10. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 10. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 10. Рис. 3.1. Свойства, формирующие блочный элемент

Рис. 3.10. Превышение размеров блока

Код, приводящий к подобному результату, приведен в примере 3.7.

Пример 3.7. Превышение размеров блока

XHTML 1.0 CSS 2.1 IE Cr Op Sa Fx

какая высота будет у блока описываемого в коде ниже. 3 11a. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 11a. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 11a. Рис. 3.1. Свойства, формирующие блочный элемент

какая высота будет у блока описываемого в коде ниже. 3 11b. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 11b. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 11b. Рис. 3.1. Свойства, формирующие блочный элемент

Рис. 11. Использование свойства overflow

Если задать одновременно цвет фона и пунктирную границу блока, то становится заметно, что граница проходит внутри цветной области. Правда в разных браузерах наблюдается разночтение, в частности Internet Explorer до версии 7.0 включительно содержит ошибку, при которой фон выводится по внутреннему краю границы (рис. 12в). Начиная с версии 8.0 эта ошибка исправлена, и фон выводится по стандартам (рис. 12г). Браузеры Opera (рис. 12а), Firefox (12б), Safari и Chrome (рис. 12д) фон выводят правильно. Небольшие различия наблюдаются при отображении пунктирной рамки, но они не влияют на блочную модель.

какая высота будет у блока описываемого в коде ниже. 3 12a. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 12a. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 12a. Рис. 3.1. Свойства, формирующие блочный элемент

какая высота будет у блока описываемого в коде ниже. 3 12b. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 12b. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 12b. Рис. 3.1. Свойства, формирующие блочный элемент

какая высота будет у блока описываемого в коде ниже. 3 12c. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 12c. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 12c. Рис. 3.1. Свойства, формирующие блочный элемент

какая высота будет у блока описываемого в коде ниже. 3 12d. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 12d. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 12d. Рис. 3.1. Свойства, формирующие блочный элемент

какая высота будет у блока описываемого в коде ниже. 3 12e. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-3 12e. картинка какая высота будет у блока описываемого в коде ниже. картинка 3 12e. Рис. 3.1. Свойства, формирующие блочный элемент

Рис. 12. Отображение фона в браузере

В примере 3.8 показано, как создать код для получения подобной границы.

Пример 3.8. Фон и граница

XHTML 1.0 CSS 2.1 IE 7 IE 8+ Cr Op Sa Fx

Различия в подходе браузеров при рисовании границ заметны только на цветном фоне и пунктирных линиях. Для сплошной рамки вид блока в браузерах будет практически одинаковым.

Источник

Блочная модель CSS

Блочная модель CSS в английском языке называется Box model (box – это коробка). Этот перевод немного помогает понять суть блочной модели. Суть в том, что при формировании страницы на экране используются блоки – прямоугольные области экрана.

Блочная модель CSS – это одна из основ для понимания CSS, модель форматирования документа.

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

Давайте на примере рассмотрим отличия этих групп элементов.

Этот пример наглядно показывает что теги

занял всю ширину экрана, его высота равна высоте его содержимого. Чтобы это было видно, для обоих элементов установлен жёлтый фоновый цвет.

Тег просто отформатировал текст внутри блока

. Тег – это строчный элемент, он не создал своего блока.

Подробнее про блоки.

Любой блочный элемент имеет установленный набор свойств, которые можно менять при помощи CSS.

Проще показать это в виде рисунка.

какая высота будет у блока описываемого в коде ниже. box model. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-box model. картинка какая высота будет у блока описываемого в коде ниже. картинка box model. Рис. 3.1. Свойства, формирующие блочный элемент

Мы видим, что кроме самого поля контента, у блока есть ещё три свойства:

В рамках этой статьи свойство outline мы рассматривать не будем. Только отмечу: на размер блока это свойство не влияет.

Остальными свойствами можно управлять при помощи CSS устанавливая их размер и некоторые другие стилевые значения. Давайте рассмотрим это на примере.

Результат должен быть такой:

какая высота будет у блока описываемого в коде ниже. blochnaja model v css 2. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-blochnaja model v css 2. картинка какая высота будет у блока описываемого в коде ниже. картинка blochnaja model v css 2. Рис. 3.1. Свойства, формирующие блочный элементРисунок 2. Работа примера №2.

Мы видим чёрную ( black ) рамку толщиной 3px вокруг блока, созданного тегом

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

Как устанавливаются фоновые цвета для этих свойств?

Расширенные возможности управления свойствами блока

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

какая высота будет у блока описываемого в коде ниже. . какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-. картинка какая высота будет у блока описываемого в коде ниже. картинка . Рис. 3.1. Свойства, формирующие блочный элементРисунок 3. Блочная модель CSS.

Рассмотрим подробнее свойства блоков и приведём примеры их использования.

Внутренний отступ – padding

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

Результат должен быть такой:

какая высота будет у блока описываемого в коде ниже. blochnaja model v css 3. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-blochnaja model v css 3. картинка какая высота будет у блока описываемого в коде ниже. картинка blochnaja model v css 3. Рис. 3.1. Свойства, формирующие блочный элементРисунок 4. Работа примера №3.

Мы видим красиво оформленный блок с внутренними отступами до границы.

Граница – border

Результат выполнения кода должен быть такой:

какая высота будет у блока описываемого в коде ниже. blochnaja model v css 4. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-blochnaja model v css 4. картинка какая высота будет у блока описываемого в коде ниже. картинка blochnaja model v css 4. Рис. 3.1. Свойства, формирующие блочный элементРисунок 5. Работа примера №4.

Внешний отступ – margin

Особенности внешних отступов.

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

какая высота будет у блока описываемого в коде ниже. blochnaja model v css 5. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-blochnaja model v css 5. картинка какая высота будет у блока описываемого в коде ниже. картинка blochnaja model v css 5. Рис. 3.1. Свойства, формирующие блочный элементРисунок 6. Работа примера №5.

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

принял фоновый цвет тега

находящиеся вне этого блока, имеют белый цвет внешнего отступа, соответствующий фоновому цвету блока по умолчанию.

Ширина блока

Ширина блока – составная величина, она складывается из суммы значений нескольких свойств:

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

На рисунке 7 блок обозначен чёрной пунктирной линией.

какая высота будет у блока описываемого в коде ниже. box model width. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-box model width. картинка какая высота будет у блока описываемого в коде ниже. картинка box model width. Рис. 3.1. Свойства, формирующие блочный элементРисунок 7. Ширина блока.

Посчитаем ширину блока на примере следующего стиля:

Сложим все слагаемые, составляющие ширину блока:

Ширина блока = 400 + 5*2 + 3*2 + 7*2 = 430px.

Устаревшая блочная модель

какая высота будет у блока описываемого в коде ниже. . какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-. картинка какая высота будет у блока описываемого в коде ниже. картинка . Рис. 3.1. Свойства, формирующие блочный элементРисунок 8. Две блочные модели.

В сети сохранилось огромное количество старых документов, которые создавались в старой блочной модели, которую также называют «режим совместимости». Поэтому списывать её со счетов не стоит.

Свойство box-sizing

Высота блока

На рисунке 9 показаны все свойства, из которых складывается суммарная высота блока, обозначенного чёрным пунктиром.

какая высота будет у блока описываемого в коде ниже. box model height. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-box model height. картинка какая высота будет у блока описываемого в коде ниже. картинка box model height. Рис. 3.1. Свойства, формирующие блочный элементРисунок 9. Высота блока.

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

Блоку также задан фоновый цвет, чтобы была видна его площадь. Вот как он выглядит:

какая высота будет у блока описываемого в коде ниже. blochnaja model v css 6. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-blochnaja model v css 6. картинка какая высота будет у блока описываемого в коде ниже. картинка blochnaja model v css 6. Рис. 3.1. Свойства, формирующие блочный элементРисунок 10. Работа примера №6.

Мы видим что по горизонтали образовалась полоса прокрутки, размер которой в два раза превышает размер окна браузера, т.е. блок по ширине всегда равен 200% от родительского элемента – окна браузера. Но во вертикали такого эффекта нет. Использование процентов для указания высоты не имеет смысла, так как высота высота родителя по умолчанию не существует и её надо указывать.

Тут родительскому элементу для

какая высота будет у блока описываемого в коде ниже. blochnaja model v css 7. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-blochnaja model v css 7. картинка какая высота будет у блока описываемого в коде ниже. картинка blochnaja model v css 7. Рис. 3.1. Свойства, формирующие блочный элементРисунок 11. Работа примера №7.

Видно, что площадь окрашенная в цвет #F3F3D6 увеличилась. Если окно браузера ещё уменьшить по высоте, то появится вертикальная полоса прокрутки, чего в прошлом примере не было.

Только установив высоту в 100% для тегов и мы сможем установить высоту в процентах для тега

какая высота будет у блока описываемого в коде ниже. blochnaja model v css 8. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-blochnaja model v css 8. картинка какая высота будет у блока описываемого в коде ниже. картинка blochnaja model v css 8. Рис. 3.1. Свойства, формирующие блочный элементРисунок 12. Работа примера №8.

При работе с высотой блока следует помнить о ещё одной особенности, если контент превышает размер блока, то он выходит за его рамки. Вот пример такого кода:

На примере видно, что текст вышел за границы блока.

какая высота будет у блока описываемого в коде ниже. blochnaja model v css 9. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-blochnaja model v css 9. картинка какая высота будет у блока описываемого в коде ниже. картинка blochnaja model v css 9. Рис. 3.1. Свойства, формирующие блочный элементРисунок 13. Работа примера №9.

Добавим в стиль примера №9 свойство overflow со значением auto и результат будет таким:

какая высота будет у блока описываемого в коде ниже. blochnaja model v css 10. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-blochnaja model v css 10. картинка какая высота будет у блока описываемого в коде ниже. картинка blochnaja model v css 10. Рис. 3.1. Свойства, формирующие блочный элементРисунок 14. Свойство overflow со значением auto.

какая высота будет у блока описываемого в коде ниже. blochnaja model v css 11. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-blochnaja model v css 11. картинка какая высота будет у блока описываемого в коде ниже. картинка blochnaja model v css 11. Рис. 3.1. Свойства, формирующие блочный элементРисунок 14. Свойство overflow со значением hidden.

Минимальная и максимальная ширина элемента

В этой статье также уместно вспомнить свойства min-width и max-width устанавливающие минимальную и максимальную ширину элемента соответственно.

В таблице приведены правила расчёта браузерами ширины блока при использовании этих свойств.

Свойство max-width – устанавливает максимальную ширину элемента.

Пример использования свойства min-width совместно со свойством width :

Пояснение к примеру: на ноутбуке (важна ширина экрана) блок будет иметь ширину 70%. Но если уменьшать ширину вкладки, то блок примет значение ширины 500px.

Тут срабатывают два правила из таблицы выше, а именно:

Свойство max-width мы не используем, поэтому работают эти две строки таблицы.

Минимальная и максимальная высота элемента

Источник

Блочная модель

Базовая компьютерная грамотность, установка базового ПО, базовые знания о работе с файлами, основы HTML (изучите Введение в HTML) и понимание работы CSS (изучите Введение в CSS.)

Узнать как работает блочная модель CSS, из чего она состоит и как переключиться на альтернативную модель.

Блочные и строчные элементы

В CSS мы, говоря упрощённо, имеем два типа элементов — блочные и строчные. Эти характеристики относятся к поведению блоков в контексте потока страницы и относительно других блоков на странице.

Если элемент определён как блочный, то он будет вести себя следующим образом:

Если не изменить намеренно тип отображения на строчный, то такие элементы, как заголовки (например,

, все используют block как свой внешний тип отображения по умолчанию.

Если элемент имеет тип отображения inline (строчный), то:

Экскурс: внутренний и внешний типы отображения

Здесь следует объяснить, что такое внутренние и внешние типы отображения. Как уже говорилось выше, каждый блок в CSS имеет внешний тип отображения, который определяет, блочный он или строчный.

Элементы также имеют внутренний тип отображения, который определяет расположение элементов внутри них. По умолчанию элементы внутри блока располагаются в нормальном потоке: они ведут себя так же, как и любые другие блочные или строчные элементы (как описано выше).

Примечание: Чтобы узнать больше о значениях display, и о том, как работают элементы при блочном или строчном расположении, посмотрите руководство MDN Блочное и срочное расположение.

Тем не менее, блочное и строчное расположение — это поведение web-элементов по умолчанию. Как было сказано выше, это иногда называют нормальным потоком (normal flow), потому что при отсутствии какой-либо другой инструкции элементы имеют блочное или строчное расположение.

Примеры разных типов отображения

Мы можем видеть, как строчные элементы ( inline ) ведут себя в следующем примере. Элементы в первом абзаце строчные по умолчанию и поэтому не приводят к переносу строки.

В примере вы можете заменить display: inline на display: block или display: inline-flex на display: flex для переключения между этими двумя режимами отображения.

Позже в этих уроках вы встретите такое понятие как flex-раскладка; главное, что нужно запомнить сейчас, это то, что изменение значения свойства display может изменить внешний тип отображения элемента на блочный или строчный, что меняет способ его отображения относительно других элементов в раскладке страницы.

В оставшейся части урока мы сосредоточимся на внешнем типе отображения.

Что такое блочная модель CSS?

Полностью блочная модель в CSS применяется к блочным элементам, строчные элементы используют не все свойства, определённые блочной моделью. Модель определяет, как разные части элемента — поля, рамки, отступы и содержимое — работают вместе, чтобы создать объект, который вы можете увидеть на странице. Дополнительная сложность заключается в том, что существуют стандартная и альтернативная блочные модели.

Составляющие элемента

Составляя блочный элемент в CSS мы имеем:

Рисунок ниже показывает эти слои:

какая высота будет у блока описываемого в коде ниже. box model. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-box model. картинка какая высота будет у блока описываемого в коде ниже. картинка box model. Рис. 3.1. Свойства, формирующие блочный элемент

Стандартная блочная модель CSS

Пространство, занимаемое нашим объектом с использованием стандартной блочной модели, на самом деле будет равно 410px в ширину (350 + 25 + 25 + 5 + 5) и 210px в высоту (150 + 25 + 25 + 5 + 5), поскольку отступы и рамки добавляются к размерам поля содержимого.

какая высота будет у блока описываемого в коде ниже. standard box model. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-standard box model. картинка какая высота будет у блока описываемого в коде ниже. картинка standard box model. Рис. 3.1. Свойства, формирующие блочный элемент

Примечание: Внешний отступ не считается в фактическом размере объекта. Конечно, он влияет на общее пространство, занимаемое объектом на странице, но только на внешнюю часть. Область элемента заканчивается на рамке — она не распространяется за нее.

Альтернативная блочная модель CSS

Вы можете подумать, что довольно неудобно добавлять рамки и отступы, чтобы получить реальный размер элемента, и окажетесь правы! По этой причине, спустя некоторое время после стандартной блочной модели, в CSS была введена альтернативная блочная модель. При использовании альтернативной модели любая ширина — это ширина видимой части элемента на странице, поэтому ширина области содержимого будет равна общей ширине минус ширина рамки и внутреннего отступа. Тот же CSS, который использовался выше, даст следующий результат (ширина = 350px, высота = 150px).

какая высота будет у блока описываемого в коде ниже. alternate box model. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-alternate box model. картинка какая высота будет у блока описываемого в коде ниже. картинка alternate box model. Рис. 3.1. Свойства, формирующие блочный элемент

Примечание: Интересный факт — Internet Explorer по умолчанию использовал альтернативную блочную модель без доступного механизма для переключения.

Играем с блочными моделями

Примечание: вы можете найти решение этой задачи здесь.

Использование инструментов разработчика в браузере для просмотра блочных моделей

Инструменты разработчика вашего браузера могут значительно облегчить понимание блочной модели. Если вы проверите элемент в инструментах разработчика Firefox, вы можете увидеть его размер, а также внешний и внутренний отступы и рамку. Проверка элемента таким способом — отличный способ выяснить, действительно ли размер вашего блока такой, какой вы думаете!

какая высота будет у блока описываемого в коде ниже. box model devtools. какая высота будет у блока описываемого в коде ниже фото. какая высота будет у блока описываемого в коде ниже-box model devtools. картинка какая высота будет у блока описываемого в коде ниже. картинка box model devtools. Рис. 3.1. Свойства, формирующие блочный элемент

Внешние, внутренние отступы и рамки

Давайте рассмотрим эти свойства более подробно.

Внешний отступ (margin)

Внешний отступ — это невидимое пространство вокруг вашего элемента. Оно отталкивает другие элементы от него. Внешний отступ может быть как положительным, так и отрицательным. Негативное значение может привести к перекрытию некоторых элементов страницы. Независимо от того, используете ли вы стандартную или альтернативную блочную модель, внешний отступ всегда добавляется после расчёта размера видимого блока.

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

Схлопывание внешних отступов

Ключевой момент, который нужно понимать в отношении внешних отступов (margin), это концепция схлопывания. Если у вас есть два элемента, внешние отступы которых соприкасаются, и оба значения margin положительные, то эти значения будут объединены в одно, равное большему из двух значений. А если одно или оба значения отрицательны, то сумма отрицательных значений будет вычтена из общей суммы.

В примере ниже есть два абзаца. Первому абзацу задан margin-bottom 50 пикселей. У второго абзаца margin-top 30 пикселей. Отступы схлопываются так, что в результате margin между двумя блоками составляет 50 пикселей, а не сумму отдельных значений margin.

Существует ряд правил, которые определяют, когда внешние отступы схлопываются, а когда нет. Для получения подробной информации см. margin collapsing. Главное, что нужно сейчас помнить, — это то, что схлопывание отступов существует. Если вы создаёте пространство с внешними отступами и не получаете ожидаемого результата, вероятно, именно это и происходит.

Рамка

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

Чтобы установить индивидуальные свойства для каждой из четырёх сторон, вы можете использовать:

Для установки ширины, стиля или цвета всех рамок используйте:

Чтобы установить ширину, стиль или цвет для каждой рамки индивидуально, вы можете использовать следующие свойства:

В примере ниже мы использовали различные сокращённые и полные способы создания рамок. Поиграйте с различными свойствами, чтобы проверить, как вы поняли принципы их работы. Информацию о различных стилях, которые вы можете использовать, можно найти на страницах MDN о свойствах рамок.

Внутренний отступ (padding)

Внутренний отступ расположен между рамкой и областью контента блока. В отличии от внешних отступов (margin), вы не можете использовать отрицательные значения для padding: они должны быть положительными или равными 0. Любой применённый к вашим элементам фон будет отображаться под областью padding, поэтому внутренний отступ обычно используется, чтобы отодвинуть контент от рамок.

Блочная модель и строчные элементы

Использование display: inline-block

Элемент с display: inline-block применяет ряд свойств блочного элемента, о которых мы уже знаем:

Проверьте свои навыки!

В этой статье мы многое рассмотрели, но получится ли у вас вспомнить самую важную информацию? Вы можете пройти дополнительные тесты, чтобы убедиться, что вы всё усвоили, прежде чем двигаться дальше — см. Проверка своих навыков: блочная модель.

Заключение

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

В следующем уроке мы рассмотрим, как можно использовать фон и рамки, чтобы сделать ваши простые блоки более интересными.

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *