Модель бокса

Содержание

Модель бокса CSS описывает прямоугольный бокс, тот, что генерируется для элементов дерева документа и располагается в соответствии с моделью визуального форматирования. Страничный бокс это нестандартный вид бокса, подробно описанный в разделе страничный носитель.


8.1 Размеры бокса

Каждый бокс имеет область содержимого (скажем, текст, изображение и т.п.) и необязательное окружение - области заполнения, рамки и поля; размер всякой области специфицируется свойствами, определёнными ниже. На диаграмме показано соотношение этих областей и терминология, применяемая для ссылок на различные участки поля/margin, рамки/border и заполнения/padding:

Image illustrating the relationship between content, padding, borders, and margins.   [D]

Поле, рамка и заполнение могут быть разорваны в левом, правом, верхнем либо нижнем сегментах (скажем, на диаграмме, "LM" в левом поле, "RP" в правом заполнении, "TB" в верху рамки и т.д.).

Периметр всей из четырёх областей (содержимого, заполнения, рамки и поля) именуется "край", соответственно - всякий бокс имеет четыре края:

content edge/край содержимого либо inner edge/внутренний край
Край содержимого окружает отображаемое содержимое.
padding edge/край заполнения
Окружает заполнение бокса. Если заполнение имеет ширину 0, край заполнения - это то же, что и край содержимого. Край заполнения бокса определяет края содержащего блока, установленного боксом.
border edge/край рамки
Окружает рамку бокса. Если рамка имеет ширину 0, то край рамки - это то же, что и край заполнения.
margin edge/край поля либо outer edge/внешний край
Окружает поле бокса. Если поле имеет ширину 0, то край поля - тот же, что и край рамки.

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

Размеры области содержимого бокса - ширина содержимого и высота содержимого - зависят от нескольких факторов: имеет ли элемент, генерирующий бокс, установленные свойства 'width' либо 'height', содержит ли бокс текст либо другие боксы, является ли бокс таблицей и т.д. Ширина и высота бокса обсуждаются в главе  некоторые детали модели визуального форматирования.

Ширина бокса выводится как сумма левого и правого поля, рамки, заполнения и ширины содержимого. Высота выводится как сумма верхнего и нижнего поля, рамки, заполнения и высоты содержимого.

Стиль фона разных областей бокса определяется так:


8.2 Пример полей, заполнения и рамок

Данный пример документа HTML показывает, как поля, рамки и заполнение взаимодействуют:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN">
<HTML>
  <HEAD>
    <TITLE>Пример полей, заполнения и рамок</TITLE>
    <STYLE type="text/css">
      UL { 
        background: green; 
        margin: 12px 12px 12px 12px;
        padding: 3px 3px 3px 3px;
                                     /* Рамки не установлены */
      }
      LI { 
        color: black;                /* цвет текста - чёрный */ 
        background: gray;            /* Содержимое, заполнение будет серым */
        margin: 12px 12px 12px 12px;
        padding: 12px 0px 12px 12px; /* Подметьте, что заполнение справа 0px */
        list-style: none             /* перед элементом списка нет никаких глифов */
                                     /* Рамки не установлены */
      }
      LI.withborder {
        border-style: dashed;
        border-width: medium;        /* устанавливает ширину рамок всех сторон */
        border-color: black;
      }
    </STYLE>
  </HEAD>
  <BODY>
    <UL>
      <LI>1-й элемент списка
      <LI class="withborder">2-й элемент списка длиннее,
                             дабы показать перенос.
    </UL>
  </BODY>
</HTML>

и даёт дерево документа с (помимо других соотношений) элементом UL, в котором есть два дочерних LI.

Первая диаграмма иллюстрирует, что данный пример даст в итоге.
Вторая иллюстрирует взаимоотношения между полями, рамками и заполнением элементов UL и LI.

Image illustrating how parent and child margins, borders,
and padding relate.   [D]

Обратите внимание, что:


8.3 Свойства поля: 'margin-top', 'margin-right', 'margin-bottom', 'margin-left' и 'margin'

Свойства поля специфицируют область полей бокса. Сокращённое качество 'margin' устанавливает поле для всех четырёх сторон, в то время как другие свойства устанавливают только соответствующие стороны.

Свойства, определённые в этом разделе, относятся к типу значений <margin-width>, тот, что может устанавливаться в:

<length>
Специфицирует фиксированную ширину.
<percentage>
Процентное значение высчитывается касательно ширины содержащего блока сгенерированного бокса. Это правильно для 'margin-top' и 'margin-bottom' везде, помимо контекста страницы, где процентные значения относятся к высоте бокса страницы.
auto
См. расчёт ширины и полей.

Негативные значения свойств полей допускаются, но могут существовать ограничения, специфичные для определенных реализаций.

'margin-top', 'margin-right', 'margin-bottom', 'margin-left'
Значение:<margin-width> | inherit
Начальное:0
Применяется:  ко каждом элементам
Наследуется:нет
Процентное:относительно ширины содержащего блока
Носитель:визуальный

Это качество устанавливает верхнее, нижнее, правое и левое поля бокса.

Пример(ы):

H1 { margin-top: 2em }
'margin'
Значение:<margin-width>{1,4} | inherit
Начальное:не определено для сокращённого свойства
Применяется: ко каждом элементам
Наследуется:нет
Процентное:относительно ширины содержащего блока
Носитель:визуальный

'margin' - это сокращённое качество для установки значений 'margin-top', 'margin-right', 'margin-bottom' и 'margin-left' в одном месте в таблице жанров.

Если имеется одно значение, то оно используется ко каждому сторонам. Если дано два значения, верхнее и нижнее поля устанавливаются в первое, а правое и левое поля - во второе значение. Если дано три значения, верхнее поле устанавливается в первое, левое и правое - во второе, а нижнее поле - в третье значение. Если задано четыре значения, они используются к верхнему, правому, нижнему и левому полям соответственно.

Пример(ы):

BODY { margin: 2em }         /* все поля установлены в 2em */
BODY { margin: 1em 2em }     /* верхнее и нижнее = 1em, правое и левое = 2em */
BODY { margin: 1em 2em 3em } /* верхнее=1em, правое=2em, нижнее=3em, левое=2em */

Последнее правило равнозначно дальнейшему:

BODY {
  margin-top: 1em;
  margin-right: 2em;
  margin-bottom: 3em;
  margin-left: 2em;          /* копируется из противоположной стороны (из правой) */
}

8.3.1 Сжатие полей

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

В CSS2 вертикальные поля никогда не сжимаются.

Горизонтальные поля могут сжиматься между определёнными боксами:

См. иллюстрацию сжимаемых полей в примере полей, заполнения и рамок.


8.4 Свойства заполнения: 'padding-top', 'padding-right', 'padding-bottom', 'padding-left' и 'padding'

Свойства обтекания специфицируют ширину области заполнения бокса. Сокращённое качество 'padding' устанавливает заполнение для всех четырёх сторон, а другие свойства заполнения устанавливают соответствующие стороны.

Свойства, определённые в этом разделе, относятся к типу значений <padding-width>, тот, что может устанавливаться в:

<length>
Специфицирует фиксированную ширину.
<percentage>
Процентное, высчитывается касательно ширины содержащего блока, генерирующего бокс, в том числе и для 'padding-top' и 'padding-bottom'.

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

'padding-top', 'padding-right', 'padding-bottom', 'padding-left'
Значение:<padding-width> | inherit
Начальное:0
Применяется:  ко каждому элементам
Наследуется:нет
Процентное:относительно ширины содержащего блока
Носитель:визуальный

Эти свойства устанавливают верхнее, правое, нижнее и левое заполнение для бокса.

Пример(ы):

BLOCKQUOTE { padding-top: 0.3em }
'padding'
Значение:<padding-width>{1,4} | inherit
Начальное:не определено для сокращённого свойства
Применяется: ко каждым элементам
Наследуется: нет
Процентное:относительно ширины содержащего блока
Носитель:визуальный

Качество 'padding' - это сокращённое качество для установки 'padding-top', 'padding-right', 'padding-bottom' и 'padding-left' в одном месте в таблице жанров.

Если имеется одно значение, то оно используется ко каждом сторонам. Если дано два значения, верхнее и нижнее заполнение устанавливаются в первое, а правое и левое заполнения - во второе значение. Если дано три значения, верхнее заполнение устанавливается в первое, левое и правое - во второе, а нижнее заполнение - в третье значение. Если задано четыре значения, они используются к верхнему, правому, нижнему и левому заполнениям соответственно.


Цвет поверхности области заполнения специфицируется через качество 'background':

Пример(ы):

H1 { 
  background: white; 
  padding: 1em 2em;
}

Вышеприведённый пример специфицирует вертикальное заполнение '1em' ('padding-top' и 'padding-bottom') и горизонтальное заполнение '2em' ('padding-right' и 'padding-left'). Единицы измерения 'em' относительны к размеру шрифта элемента: '1em' равнозначно размеру используемого шрифта.


8.5 Свойства рамки

Свойства рамки специфицируют ширину, цвет и жанр области рамки бокса. Эти свойства применимы ко каждым элементам.

Примечание. Исключительно в HTML, ПА могут отображать рамки определённых элементов (скажем, кнопок, меню и т.п.) напротив, чем у "обычных" элементов.


8.5.1 Ширина рамки: 'border-top-width', 'border-right-width', 'border-bottom-width', 'border-left-width' и 'border-width'

Свойства ширины рамки специфицируют ширину области рамки. Свойства, определённые в этом разделе, относятся к типу значений <border-width>, тот, что может устанавливаться в:

thin
Тонкая рамка.
medium
Средняя рамка.
thick
Толстая рамка.
<length>
Толщина рамки имеет точное значение. Это значение не может быть отрицательным.

Интерпретация первых трёх значений зависит от ПА. Следующие соотношения, впрочем, обязаны выдерживаться:

'thin' <='medium' <= 'thick'.

К тому же эти значения ширины обязаны быть константными в пределах документа.

'border-top-width', 'border-right-width', 'border-bottom-width', 'border-left-width'
Значение:<border-width> | inherit
Начальное:medium
Применяется:  ко каждым элементам
Наследуется:нет
Процентное:N/A
Носитель:визуальный

Эти свойства устанавливают верхнюю, правую, нижнюю и левую линии рамки для бокса.

'border-width'
Значение:<border-width>{1,4} | inherit
Начальное:см. индивидуальные свойства
Применяется: ко каждому элементам
Наследуется:нет
Процентное:N/A
Носитель:визуальный

Это сокращённое качество для установки 'border-top-width', 'border-right-width', 'border-bottom-width' и 'border-left-width' в одном месте в таблице жанров.

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

Пример(ы):

Комментарии в данном примере объясняют итоги установки ширины верхней, правой, нижней и левой линий рамки:

H1 { border-width: thin }                   /* thin thin thin thin */
H1 { border-width: thin thick }             /* thin thick thin thick */
H1 { border-width: thin thick medium }      /* thin thick medium thick */

8.5.2 Цвет рамки: 'border-top-color', 'border-right-color', 'border-bottom-color', 'border-left-color' и 'border-color'

Эти свойства специфицируют цвет рамки бокса.

'border-top-color', 'border-right-color', 'border-bottom-color', 'border-left-color'
Значение:<color> | inherit
Начальное:значение свойства 'color'
Применяется:  ко каждым элементам
Наследуется:нет
Процентное:N/A
Носитель:визуальный
'border-color'
Значение:<color>{1,4} | transparent | inherit
Начальное:см. индивидуальные свойства
Применяется: ко каждым элементам
Наследуется:нет
Процентное:N/A
Носитель:визуальный

Свойство 'border-color' устанавливает цвет рамки с четырёх сторон.
Значения имеют дальнейший толк:

<color>
Специфицирует значение цвета.
transparent
Рамка прозрачна (правда и может иметь ширину).

Свойство 'border-color' может иметь от одного до четырёх значений, и эти значения устанавливаются для четырёх сторон так же, как и в 'border-width'.

Если цвет рамки элемента не специфицирован в свойстве рамки, ПА обязаны применять значение свойства 'color' элемента как вычисленное значение цвета рамки.

Пример(ы):

В этом примере рамка будет сплошной и чёрной:

P { 
  color: black; 
  background: white; 
  border: solid;
}

8.5.3 Стиль рамки: 'border-top-style', 'border-right-style', 'border-bottom-style', 'border-left-style' и 'border-style'

Свойства жанра рамки специфицируют жанр линии рамки бокса (solid, double, dashed и т.д.). Свойства, определённые в этом разделе, относятся к типу значений <border-style>, тот, что может устанавливаться в:

none
Нет рамки. Форсирует вычисленное значение 'border-width' в '0'.
hidden
То же, что и 'none', за исключением разрешения раздоров рамок для элементов таблицы.
dotted
Рамка из точек.
dashed
Рамка из пунктирных линий.
solid
Рамка из сплошной линии.
double
Двойная сплошная линия. Сумма 2-х линий и пространства между ними равна значению 'border-width'.
groove
Рамка выглядит как вырезанная в канве.
ridge
Противоположно 'groove': рамка выглядит как выступающая над канвой.
inset
Весь бокс выглядит вдавленным в канву.
outset
Противоположно 'inset': рельефный бокс.

Все рамки прорисовываются на поверхности фона бокса. Цвет рамок со значениями 'groove', 'ridge', 'inset' и 'outset' зависит от свойства 'color' элемента.

Соответствующие пользовательские агенты (ПА) HTML могут интерпретировать 'dotted', 'dashed', 'double', 'groove', 'ridge', 'inset' и 'outset' как 'solid'.

'border-top-style', 'border-right-style', 'border-bottom-style', 'border-left-style'
Значение:<border-style> | inherit
Начальное:none
Применяется:  ко каждым элементам
Наследуется:нет
Процентное:N/A
Носитель:визуальный
'border-style'
Значение:<border-style>{1,4} | inherit
Начальное:см. индивидуальные свойства
Применяется:  ко каждым элементам
Наследуется:нет
Процентное:N/A
Носитель:визуальный

Свойство 'border-style' устанавливает жанр для четырёх сторон рамки. Может иметь от одного до четырёх значений, и значения устанавливаются для различных сторон, как для 'border-width' выше.

Пример(ы):

#xy34 { border-style: solid dotted }

В этом примере горизонтальные линии рамки будут 'solid', а вертикальные - 'dotted'.

Поскольку исходное значение жанра рамки - 'none', рамка будет видна только позже установки значения жанра.


8.5.4 Сокращённые свойства рамок: 'border-top', 'border-bottom', 'border-right', 'border-left' и 'border'

'border-top', 'border-right', 'border-bottom', 'border-left'
Значение:[ <'border-top-width'> || <'border-style'> || <color> ] | inherit
Начальное:см. индивидуальные свойства
Применяется:  ко каждым элементам
Наследуется:нет
Процентное:N/A
Носитель:визуальный

Это сокращённое качество для установки ширины, жанра и цвета верхней, правой, нижней и левой сторон рамки.

Пример(ы):

H1 { border-bottom: thick solid red }

Это правило устанавливает ширину, жанр и цвет рамки после элемента H1. Опущенные значения установлены в свои начальные значения. От того что нижеследующее правило не специфицирует цвет рамки, рамка будет иметь цвет, определённый свойством 'color':

H1 { border-bottom: thick solid }
'border'
Значение:[ <'border-width'> || <'border-style'> || <color> ] | inherit
Начальное:см. индивидуальные свойства
Применяется:  ко каждым элементам
Наследуется:нет
Процентное:N/A
Носитель:визуальный

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

Пример(ы):

Первое правило равнозначно установке четырёх последующих значений:

P { border: solid red }
P {
  border-top: solid red;
  border-right: solid red;
  border-bottom: solid red;
  border-left: solid red
}

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

Пример(ы):

BLOCKQUOTE {
  border-color: red;
  border-left: double;
  color: black
}

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