3 Соответствие: Требования и Рекомендации
В этом разделе мы начинаем формальную спецификацию CSS2 с соглашения между
авторами, пользователями и исполнителями.
Ключевые слова "ОБЯЗАН",
"НЕ ОБЯЗАН", "НЕОБХОДИМ", "БУДЕТ", "НЕ БУДЕТ", "ДОЛЖЕН", "НЕ ДОЛЖЕН",
"МОЖЕТ", "РЕКОМЕНДУЕТСЯ"
И "НЕОБЯЗАТЕЛЕН"
в этом документе интерпретируются так, как
описано в [RFC2119].
Однако, для удобства чтения эти слова не употребляются в этой спецификации со всеми
буквами в верхнем регистре.
Время от времени авторы этой спецификации дают практические рекомендации
для авторов и пользовательских агентов (ПА). Эти рекомендации не являются нормативными и
соответствие с этой спецификацией не
зависит от их реализации. Эти рекомендации
содержат выражения типа: "мы рекомендуем ...", "эта спецификация рекомендует ...", или
другие подобные конструкции.
- Таблица стилей
- Набор операторов, специфицирующих
представление документа.
Таблицы стилей
могут иметь три различных источника: автор, пользователь и ПА. Взаимодействие этих
источников описано в разделе Каскадирование
и наследование.
- Действующие таблицы стилей
- Статус таблицы стилей зависит от уровня CSS,
используемого в таблице стилей. Все
действующие таблицы стилей CSS1 являются
действующими и в CSS2. Однако некоторые изменения по сравнению
с CSS1 указывают, что некоторые таблицы
стилей CSS1 будут иметь несколько другую
семантику в
CSS2.
Действующая таблица стилей CSS2 обязана
быть написана в соответствии с грамматикой CSS2. Кроме того, она
обязана содержать только at-правила,
названия свойств и значения свойств,
определённые в данной спецификации. Неверное at-правило,
название свойства или значение свойства -
это то, которое имеет неверное значение.
- Документ-источник
- Документ, на который ссылается одна или более таблиц стилей. Он кодирован в том же языке, в котором документ представлен как
дерево элементов. Каждый элемент состоит из имени, идентифицирующего тип
элемента, нескольких необязательных атрибутов и (возможно пустого) содержимого.
- Язык документа
- Язык кодировки документа-источника (например, HTML или XML).
- Элемент
- (Термин SGML, см. [ISO8879].)
Первичные синтаксические конструкции языка документа. Большинство правил
таблиц стилей CSS используют имена элементов (такие как "P", "TABLE" и "OL" в
HTML) для спецификации информации для их представления.
-
Замещаемый элемент
- Элемент, для которого форматировщик CSS знает только внутренние размеры. В HTML
элементы IMG, INPUT, TEXTAREA, SELECT и OBJECT можно привести в качестве примеров таких
элементов. Например, содержимое элемента IMG часто замещается изображением, на которое
указывает атрибут "src". CSS не определяет, как находить внутренние размеры.
- Внутренние размеры
- Ширина и высота, определённые самим элементом, а не его окружением. В CSS2 принято, что все замещаемые элементы - и
только замещаемые элементы - появляются с внутренними размерами.
- Атрибут
- Значение, ассоциированное с элементом, состоящее из названия и ассоциированного значения.
- Содержимое
- Содержимое, ассоциированное с элементом в документе-источнике;
не все элементы
имеют содержимое, и в этом случае они называются пустыми.
Содержимое элемента может быть текстом и может включать несколько субэлементов,
тогда такой элемент называется родительским (элементом-предком) для субэлементов.
- Выводимое содержимое
- Содержимое элемента после вывода,
которое представляется в соответствии с
подключённой таблицей стилей. Выводимое
содержимое замещаемых элементов
поступает извне документа-источника.
Выводимое содержимое может быть также
альтернативным текстом для данного
элемента (например, значением атрибута "alt"
в HTML) и может включать объекты, вставленные,
явно или неявно, таблицей стилей:
маркировка или нумерация списков и т.п.
-
Дерево документа
- Дерево элементов, кодированных в документе-источнике. Каждый элемент в этом
дереве имеет только одного предка, за исключением элемента root, который предков не имеет.
- Дочерний элемент
- Элемент А называется дочерним элементом элемента В, если только В является родителем А.
- Потомок
- Элемент А называется потомком элемента В, если (1) А является дочерним по отношению к
В, или (2) если А является дочерним относительно элемента С, который является потомком В.
- Предок (родительский элемент)
- Элемент А называется предком элемента В, если, и только если, В является потомком А.
- Родственник
- Элемент А называется родственником элемента В, если, и только если, В и А имеют
одного общего предка.
Элемент А является предшествующим родственником, если появляется перед В в
дереве документа.
Элемент В является последующим родственником, если появляется после А в
дереве документа.
- Предшествующий элемент
- Элемент А называется предшествующим элементу В, если, и только если, (1) А
является предком В или (2) А является предшествующим родственником В.
- Последующий элемент
- Элемент А называется последующим элементом для В, если, и только если, В является предшествующим элементом для А.
- Автор
- Тот, кто пишет документы и ассоциированные таблицы стилей.
-
- Авторская утилита генерирует документы и
ассоциированные таблицы стилей.
- Пользователь
- Тот, кто взаимодействует с пользовательским агентом
(ПА) для просмотра, прослушивания или другого использования
документа и ассоциированной таблицы стилей. Пользователь может предоставлять персональную таблицу стилей, которая
кодирует персональные установки-предпочтения.
- Пользовательский агент (ПА)
- Это какая-либо программа, интерпретирующая документ, написанный на определённом языке документов, и
ассоциированную с ним таблицу стилей в соответствии с терминами данной спецификации. ПА может отображать
документ, "читать" его вслух, распечатывать его,
конвертировать его в другой формат и т.п.
Это пример документа-источника, кодированного в HTML:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN">
<HTML>
<TITLE>My home page</TITLE>
<BODY>
<H1>My home page</H1>
<P>Welcome to my home page! Let me tell you about my favorite
composers:
<UL>
<LI> Elvis Costello
<LI> Johannes Brahms
<LI> Georges Brassens
</UL>
</BODY>
</HTML>
Это дерево данного документа:
В соответствии с определением HTML,
элементы HEAD будут вставлены во время
разбора и станут частью дерева документа,
даже если тэги HEAD отсутствовали в документе-источнике.
Таким же образом, разборщик "знает",
где заканчиваются элементы P и LI, даже если
они не имеют тэгов </P> и </LI> в
источнике.
Этот раздел определяет соответствие
только со спецификацией CSS2.
В будущем могут появиться другие уровни CSS,
что может потребовать в будущем от ПА
выполнения другого набора свойств, чтобы
соответствовать.
В общем, следующие пункты обязательно должны учитываться ПА, претендующим на
соответствие данной спецификации:
- Он обязан поддерживать один или более типов носителя CSS2.
- Для каждого документа-источника он обязан запросить все ассоциированные
таблицы стилей, подходящие для поддерживаемых типов носителя.
Если он не может запросить все ассоциированные таблицы стилей (к примеру,
из-за ошибок в сети), он обязан вывести документ с использованием тех таблиц,
которые он может запросить.
- Он обязан разобрать таблицы стилей в соответствии с данной спецификацией.
В частности, он обязан распознавать все at-правила,
блоки, объявления и селекторы (см. грамматику CSS2).
Если ПА обнаруживает свойство, применимое
к поддерживаемому типу носителя, то ПА
обязан разобрать значение в соответствии
с определением свойства. Это
значит, что ПА
обязан принять все верные значения и
игнорировать объявления с неверными
значениями. ПА обязаны игнорировать
правила, применяемые к неподдерживаемым типам
носителя.
- В каждом элементе дерева документа
ПА обязан назначить значение для каждого
применимого свойства в соответствии с определением свойства и с правилами каскадирования
и наследования.
- Если документ-источник поступает с альтернативными таблицами стилей (как с ключевым словом
"alternate" в HTML 4.0 [HTML40]),
ПА обязан предоставить пользователю
возможность выбрать одну из нескольких
таблиц стилей и применить её.
Не каждый ПА обязан следовать всем пунктам, однако:
- ПА, который вводит таблицы стилей, обязан следовать пунктам 1 - 3.
- Авторская утилита должна только производить действующие таблицы стилей
- ПА, который выводит документ с ассоциированными таблицами стилей, обязан
следовать пунктам 1 - 5 и представлять документ в соответствии со специфическими требованиями носителя, установленными
далее в этой спецификации. Значения при необходимости могут быть приближены
ПАгентом.
Невозможность для ПА выполнить часть
данной спецификации из-за ограничений
конкретного устройства (например, ПА не
может вывести цвета на монохромном
мониторе) не означает несоответствие.
Данная спецификация рекомендует, чтобы ПА
позволял пользователю специфицировать
пользовательские таблицы стилей.
В общем, данный документ не специфицирует
для ПА поведение при обработке ошибок (например,
как ПА ведут себя, если не могут найти
ресурс, указанный в URI).
Однако ПА обязаны
соблюдать правила обработки
ошибок разбора.
Поскольку ПА могут
различаться в способах обработки ошибочных
условий, авторы и пользователи не обязаны полагаться
на специфическое поведение при обработке
ошибок.
Таблицы стилей CSS, находящиеся во внешнем файле, пересылаются по Internet как
последовательность байтов, сопровождаемая
информацией о кодировании (см. [HTML40],
гл. 5). Структура переноса, называемая сущность сообщения,
определена в RFC 2045 и RFC 2068 (см. [RFC2045]
и [RFC2068]).
Сущность сообщения вместе с типом
содержимого "text/css" представляет
независимый документ CSS. Тип содержимого
"text/css" был зарегистрирован в RFC 2138 ([RFC2318]).