CSS - CSS

Каскадные таблицы стилей (CSS)
Логотип CSS3 и wordmark.svg
Расширение имени файла
.css
Тип интернет-СМИ
текст / css
Единый идентификатор типа (UTI)public.css
РазработанКонсорциум World Wide Web (W3C)
изначальный выпуск17 декабря 1996 г.; 23 года назад (1996-12-17)
Последний релиз
CSS 2.1: уровень 2, редакция 1
(12 апреля 2016 г.; 4 года назад (2016-04-12))
Тип форматаЯзык таблиц стилей
Контейнер дляПравила стиля для HTML-элементы (теги)
СодержитсяHTML-документы
Открытый формат ?да
Интернет сайтwww.w3.org/ TR/ CSS2/

Каскадные таблицы стилей (CSS) это язык таблиц стилей используется для описания презентация документа, написанного в язык разметки такие как HTML.[1] CSS - это краеугольная технология Всемирная сеть, наряду с HTML и JavaScript.[2]

CSS предназначен для разделения представления и содержимого, в том числе макет, цвета, и шрифты.[3] Это разделение может улучшить контент доступность, обеспечивают большую гибкость и контроль при указании характеристик представления, позволяют несколько веб-страница для совместного использования форматирования путем указания соответствующего CSS в отдельном файле .css, что снижает сложность и повторяемость структурного содержимого, а также позволяет использовать файл .css кешированный для повышения скорости загрузки страницы между страницами, которые совместно используют файл, и его форматирования.

Разделение форматирования и содержимого также позволяет представлять одну и ту же страницу разметки в разных стилях для разных методов визуализации, например на экране, в печати, голосом (через браузер на основе речи или читатель экрана ) и на На основе Брайля тактильные устройства. В CSS также есть правила для альтернативного форматирования, если доступ к контенту осуществляется через мобильное устройство.[4]

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

Спецификации CSS поддерживаются Консорциум World Wide Web (W3C). Тип интернет-СМИ (Тип MIME ) текст / css зарегистрирован для использования с CSS RFC 2318 (Март 1998 г.). W3C управляет бесплатным Служба проверки CSS для документов CSS.[5]

Помимо HTML, другие языки разметки поддерживают использование CSS, включая XHTML, простой XML, SVG, и XUL.

Синтаксис

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

Таблица стилей состоит из списка правила. Каждое правило или набор правил состоит из одного или нескольких селекторы, а блок объявлений.

Селектор

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

Селекторы могут применяться к следующему:

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

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

Псевдоклассы используются в селекторах CSS, чтобы разрешить форматирование на основе информации, не содержащейся в дереве документа. Одним из примеров широко используемого псевдокласса является :парить, который идентифицирует контент только тогда, когда пользователь «указывает» на видимый элемент, обычно удерживая курсор мыши над ним. Он добавляется к селектору, как в а:парить или #элементарный:парить. Псевдокласс классифицирует элементы документа, такие как :ссылка на сайт или :посетил, тогда как псевдоэлемент делает выбор, который может состоять из частичных элементов, таких как ::первая линия или ::первое письмо.[6]

Селекторы можно комбинировать разными способами для достижения большей специфичности и гибкости.[7] Несколько селекторов могут быть объединены в разнесенный список для определения элементов по местоположению, типу элемента, идентификатору, классу или любой их комбинации. Порядок селекторов важен. Например, div .мой класс {цвет: красный;} применяется ко всем элементам класса myClass, которые находятся внутри элементов div, тогда как .мой класс div {цвет: красный;} применяется ко всем элементам div, которые находятся в элементах класса myClass.

В следующей таблице приводится сводка синтаксиса селектора с указанием использования и версии CSS, в которой он появился.[8]

ШаблонсовпаденияПервое определение
на уровне CSS
Eэлемент типа E1
E:ссылка на сайтэлемент E является якорем источника гиперссылки, цель которой еще не посещена (: ссылка) или уже посещена (: посещена)1
E:активныйэлемент E во время определенных действий пользователя1
E::первая линияпервая отформатированная строка элемента E1
E::первое письмопервая форматированная буква элемента E1
.cвсе элементы с class = "c"1
#мой IDэлемент с id = "myid"1
E.предупреждениеэлемент E, класс которого - "предупреждение" (язык документа определяет, как класс определяется)1
E#мой IDэлемент E с идентификатором, равным "myid"1
.c#мой IDэлемент с class = "c" и идентификатором, равным "myid"1
E Fэлемент F, потомок элемента E1
*любой элемент2
E[фу]элемент E с атрибутом "foo"2
E[фу="бар"]элемент E, значение атрибута "foo" которого точно равно "bar"2
E[фу~="бар"]элемент E, значение атрибута «foo» которого представляет собой список значений, разделенных пробелами, одно из которых точно равно «bar»2
E[фу|="en"]элемент E, атрибут "foo" которого содержит список значений, разделенных дефисом, начинающийся (слева) с "en"2
E:Первый ребенокэлемент E, первый дочерний элемент своего родителя2
E:язык(fr)элемент типа E на языке "fr" (язык документа определяет способ определения языка)2
E::передсгенерированное содержимое перед содержимым элемента E2
E::послесгенерированный контент после содержимого элемента E2
E > Fдочерний элемент F элемента E2
E + Fэлемент F, которому непосредственно предшествует элемент E2
E[фу^="бар"]элемент E, значение атрибута "foo" которого начинается точно со строки "bar"3
E[фу$="бар"]элемент E, значение атрибута "foo" которого заканчивается точно строкой "bar"3
E[фу*="бар"]элемент E, значение атрибута "foo" которого содержит подстроку "bar"3
E:кореньэлемент E, корень документа3
E:n-й ребенок(п)элемент E, n-й дочерний элемент своего родителя3
E:nth-последний-ребенок(п)элемент E, n-й дочерний элемент своего родителя, считая от последнего3
E:nth-типа(п)элемент E, n-й брат своего типа3
E:n-й-последний-тип(п)элемент E, n-й брат своего типа, считая от последнего3
E:последний ребенокэлемент E, последний дочерний элемент своего родителя3
E:первоклассныйэлемент E, первый родственник своего типа3
E:последний в своем родеэлемент E, последний родственник этого типа3
E:единственный ребенокэлемент E, единственный дочерний элемент своего родителя3
E:единственный в своем родеэлемент E, единственный родственник своего типа3
E:пустойэлемент E, у которого нет дочерних элементов (включая текстовые узлы)3
E:цельэлемент E, являющийся целью ссылающегося URI3
E:включенэлемент пользовательского интерфейса E, который включен3
E:отключенэлемент пользовательского интерфейса E, который отключен3
E:проверилотмеченный элемент пользовательского интерфейса E (например, радио-кнопка или флажок)3
E:нет(s)элемент E, который не соответствует простому селектору s3
E ~ Fэлемент F, которому предшествует элемент E3

Блок объявления

Блок объявлений состоит из списка декларации в подтяжках. Каждое объявление состоит из свойство, двоеточие (:), а ценность. Если в блоке несколько объявлений, точка с запятой (;) должны быть вставлены для разделения каждого объявления. An необязательный может использоваться точка с запятой после последнего (или единственного) объявления.[9]

Свойства указаны в стандарте CSS. У каждого свойства есть набор возможных значений. Некоторые свойства могут влиять на любой тип элемента, а другие применяются только к определенным группам элементов.[10][11]

Значения могут быть ключевыми словами, такими как «центр» или «наследование», или числовыми значениями, например 200 пикселей (200 пикселей), 50vw (50 процентов ширины области просмотра) или 80% (80 процентов ширины родительского элемента). Значения цвета можно указать с помощью ключевых слов (например, "красный"), шестнадцатеричные значения (например, # FF0000, также сокращенно # F00), Значения RGB от 0 до 255 (например, rgb (255, 0, 0)), Значения RGBA, указывающие как цвет, так и альфа-прозрачность (например, rgba (255, 0, 0, 0,8)), или значения HSL или HSLA (например, hsl (000, 100%, 50%), hsla (000, 100%, 50%, 80%)).[12]

Единицы длины

Ненулевые числовые значения, представляющие линейные меры, должны включать единицу длины, которая представляет собой буквенный код или аббревиатуру, как в 200 пикселей или 50vw; или знак процента, как в 80%. Некоторые единицы - см (сантиметр ); в (дюйм ); мм (миллиметр ); ПК (пика ); и pt (точка ) - находятся абсолютный, что означает, что отображаемый размер не зависит от структуры страницы; другие - Эм (Эм ); бывший (бывший ) и px (пиксель ) - находятся родственник, что означает, что такие факторы, как размер шрифта родительского элемента, могут повлиять на отображаемое измерение. Эти восемь модулей были особенностью CSS 1[13] и сохраняется во всех последующих редакциях. Предлагаемый модуль значений и единиц CSS уровня 3, если он будет принят в качестве рекомендации W3C, предоставит еще семь единиц длины: ch; Q; rem; vh; vmax; vmin; и vw.[14]

Использовать

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

Например, заголовки (h1 элементы), подзаголовки (h2), подзаголовки (h3) и т. д., структурно определены с помощью HTML. В печати и на экране выбор шрифт, размер, цвет и акцент для этих элементов презентационный.

До появления CSS авторы документов, которые хотели назначить такие типографский характеристики, скажем, для всех h2 заголовки должны были повторять презентационную разметку HTML для каждого вхождения этого типа заголовка. Это сделало документы более сложными, крупными, подверженными ошибкам и сложными в обслуживании. CSS позволяет отделить представление от структуры. CSS может определять цвет, шрифт, выравнивание текста, размер, границы, интервал, макет и многие другие типографские характеристики и может делать это независимо для экранных и печатных видов. CSS также определяет невизуальные стили, такие как скорость чтения и акцент для чтения на слух. В W3C теперь устарел использование всей презентационной разметки HTML.[15]

Например, в HTML до CSS элемент заголовка, определенный красным текстом, будет записан как:

<h1><шрифт цвет="красный">Глава 1.</шрифт></h1>

Используя CSS, тот же элемент можно закодировать, используя свойства стиля вместо атрибутов представления HTML:

<h1 стиль="красный цвет;">Глава 1.</h1>

Преимущества этого могут быть не сразу очевидны, но мощь CSS становится более очевидной, когда свойства стиля помещаются во внутренний элемент стиля или, что еще лучше, во внешний файл CSS. Например, предположим, что документ содержит элемент стиля:

<стиль>    h1 {        цвет: красный;    }</стиль>

Все h1 элементы в документе автоматически станут красными без необходимости в явном коде. Если автор позже захотел сделать h1 элементы синего цвета, это можно сделать, изменив элемент стиля на:

<стиль>    h1 {        цвет: синий;    }</стиль>

вместо того, чтобы кропотливо просматривать документ и менять цвет для каждого человека h1 элемент.

Стили также могут быть помещены во внешний файл CSS, как описано ниже, и загружены с использованием синтаксиса, подобного следующему:

<ссылка на сайт href="путь / к / file.css" rel="таблица стилей" тип="текст / CSS">

Это дополнительно отделяет стиль от HTML-документа и позволяет изменять стиль нескольких документов, просто редактируя общий внешний файл CSS.

Источники

Информация CSS может быть предоставлена ​​из различных источников. Этими источниками могут быть веб-браузер, пользователь и автор. Информация от автора может быть дополнительно классифицирована по встроенным, типам мультимедиа, важности, специфичности селектора, порядку правил, наследованию и определению свойств. Информация о стиле CSS может быть в отдельном документе или встроена в документ HTML. Можно импортировать несколько таблиц стилей. В зависимости от используемого устройства вывода могут применяться разные стили; например, экранная версия может сильно отличаться от печатной, поэтому авторы могут адаптировать презентацию для каждого носителя.

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

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

Схема приоритета CSS (от высшего к низшему)
ПриоритетТип источника CSSОписание
1Важность"!важный"аннотация перезаписывает предыдущие типы приоритета
2В соответствииСтиль, применяемый к HTML-элементу с помощью атрибута HTML "style"
3Тип носителяОпределение свойства применяется ко всем типам мультимедиа, если не определен CSS, специфичный для мультимедиа.
4Определяемые пользователемВ большинстве браузеров есть функция доступности: определенный пользователем CSS.
5Специфика селектораКонкретный контекстный селектор (#заголовок п) перезаписывает общее определение
6Порядок правилОбъявление последнего правила имеет более высокий приоритет
7Родительское наследованиеЕсли свойство не указано, оно наследуется от родительского элемента.
8Определение свойства CSS в документе HTMLПравило CSS или встроенный стиль CSS перезаписывают значение браузера по умолчанию
9Браузер по умолчаниюСамый низкий приоритет: значение браузера по умолчанию определяется спецификациями начального значения W3C.

Специфика

Специфика относится к относительным весам различных правил.[16] Он определяет, какие стили применяются к элементу, если может применяться более одного правила. В зависимости от спецификации простой селектор (например, H1) имеет специфичность 1, селекторы классов имеют специфичность 1,0, а селекторы идентификаторов имеют специфичность 1,0,0. Поскольку значения специфичности не переносятся, как в десятичной системе, запятые используются для разделения «цифр».[17] (правило CSS, содержащее 11 элементов и 11 классов, будет иметь специфичность 11,11, а не 121).

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

СелекторыСпецифика
h1 {цвет: белый;}0, 0, 0, 1
п Эм {цвет: зеленый;}0, 0, 0, 2
.виноград {цвет: красный;}0, 0, 1, 0
п.яркий {цвет: синий;}0, 0, 1, 1
п.яркий Эм.тьма {цвет: желтый;}0, 0, 2, 2
#id218 {цвет: коричневый;}0, 1, 0, 0
стиль=" "1, 0, 0, 0

Примеры

Рассмотрим этот фрагмент HTML:

<!DOCTYPE html><html>    <голова>        <мета кодировка=«УТФ-8»>        <стиль>            #xyz { цвет: синий; }        </стиль>    </голова>    <тело>        <п я бы="xyz" стиль=«цвет: зеленый»;>Чтобы продемонстрировать специфичность</п>    </тело></html>

В приведенном выше примере объявление в стиль атрибут переопределяет один в <style> элемент, потому что он имеет более высокую специфичность, и поэтому абзац отображается зеленым.

Наследование

Наследование - ключевая особенность CSS; он полагается на отношения «предок-потомок». Наследование - это механизм, с помощью которого свойства применяются не только к указанному элементу, но и к его потомкам.[16] Наследование основывается на дереве документов, которое представляет собой иерархию XHTML элементы на странице на основе вложенности. Дочерние элементы могут наследовать значения свойств CSS от любого элемента-предка, включающего их. Как правило, дочерние элементы наследуют свойства, связанные с текстом, но их свойства, связанные с блоком, не наследуются. Свойства, которые могут быть унаследованы: цвет, шрифт, межбуквенный интервал, высота строки, стиль списка, выравнивание текста, отступ текста, преобразование текста, видимость, пробелы и интервалы между словами. Свойства, которые не могут быть унаследованы: background, border, display, float and clear, height и width, margin, min- и max-height и -width, outline, overflow, padding, position, text-decoration, vertical-align и z. -индекс.

Наследование можно использовать, чтобы не объявлять определенные свойства снова и снова в таблице стилей, что позволяет использовать более короткий CSS.

Наследование в CSS - это не то же самое, что наследование в языках программирования на основе классов, где можно определить класс B как «как класс A, но с изменениями».[18] С помощью CSS можно стилизовать элемент с «классом А, но с доработками». Однако невозможно определить CSS класс B, который затем может быть использован для стилизации нескольких элементов без повторения изменений.

пример

Учитывая следующую таблицу стилей:

h1 {   цвет: розовый;}

Предположим, есть элемент h1 с подчеркивающим элементом (em) внутри:

<h1>   Это для <Эм>иллюстрировать</Эм> наследство</h1>

Если элементу em не назначен цвет, выделенное слово «illustrate» наследует цвет родительского элемента h1. Таблица стилей h1 имеет розовый цвет, следовательно, элемент em также розовый.

Пробел

Пробелы между свойствами и селекторами игнорируются. Этот фрагмент кода:

тело{переполнение:скрытый;фон:#000000;фоновая картинка:url(images / bg.gif);фон-повтор:нет повторения;фоновая позиция:осталось верх;}

функционально эквивалентен этому:

тело {   переполнение: скрытый;   фоновый цвет: #000000;   фоновая картинка: url(images / bg.gif);   фон-повтор: нет повторения;   фоновая позиция: осталось верх;}

Один из распространенных способов форматирования CSS для удобства чтения - сделать отступ для каждого свойства и дать ему отдельную строку. В дополнение к форматированию CSS для удобства чтения, сокращенные свойства могут использоваться для более быстрого написания кода, который также быстрее обрабатывается при визуализации:[19]

тело {   переполнение: скрытый;   фон: #000 url(images / bg.gif) нет повторения осталось верх;}

Позиционирование

CSS 2.1 определяет три схемы позиционирования:

Нормальный поток
В соответствии элементы располагаются так же, как буквы в словах в тексте, одна за другой в доступном пространстве, пока не останется места, а затем начиная с новой строки ниже. Блокировать элементы располагаются вертикально, как абзацы и как элементы в маркированном списке. Нормальный поток также включает в себя относительное позиционирование блочных или встроенных элементов и полей ввода.
Поплавки
Плавающий элемент выводится из обычного потока и смещается влево или вправо, насколько это возможно, в доступном пространстве. Затем другой контент течет вместе с плавающим элементом.
Абсолютное позиционирование
Абсолютно позиционированный элемент не имеет места и не влияет на нормальный поток других элементов. Он занимает назначенное ему место в контейнере независимо от других элементов.[20]

Свойство позиции

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

Статический
Значение по умолчанию помещает элемент в нормальный поток
Родственник
Товар помещается в нормальный поток, а затем сдвигается или смещается от этой позиции. Последующие элементы потока располагаются так, как если бы элемент не был перемещен.
Абсолютное
Указывает абсолютное позиционирование. Элемент позиционируется относительно его ближайшего нестатического предка.
Исправлена
Товар абсолютно позиционируется в фиксированном положении на экране, даже когда остальная часть документа прокручивается[20]

Плавать и очищать

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

осталось
Предмет поплавки слева от строки, в которой он должен был появиться; другие предметы могут обтекать его правую сторону.
правильно
Предмет поплавки справа от строки, в которой он должен был появиться; другие предметы могут обтекать его левую сторону.
Чисто
Заставляет элемент отображаться под ('clear') плавающими элементами слева (Чисто:осталось), верно (Чисто:правильно) или обе стороны (Чисто:обе).[20][21]

История

Хокон Виум Ли, технический директор компании Opera Software и соавтор веб-стандартов CSS

CSS был впервые предложен Хокон Виум Ли 10 октября 1994 г.[22] В то время Ли работал с Тим Бернерс-Ли в ЦЕРН.[23] Примерно в то же время было предложено несколько других языков таблиц стилей для Интернета, и обсуждения в публичных списках рассылки и внутри Консорциум World Wide Web привели к первой рекомендации W3C CSS (CSS1)[24] выпущен в 1996 году. В частности, предложение Берт Бос был влиятельным; он стал соавтором CSS1 и считается соавтором CSS.[25]

Таблицы стилей существовали в той или иной форме с момента появления Standard Generalized Markup Language (SGML ) в 1980-х годах, а CSS был разработан для предоставления таблиц стилей для Интернета.[26] Одно из требований к языку веб-таблиц стилей заключалось в том, чтобы таблицы стилей поступали из разных источников в Интернете. Поэтому существующие языки таблиц стилей, такие как DSSSL и FOSI не подходили. CSS, с другой стороны, позволяет нескольким таблицам стилей влиять на стиль документа посредством «каскадных» стилей.[26]

По мере роста HTML он стал включать в себя более широкий спектр стилистических возможностей, чтобы удовлетворить потребности веб-разработчики. Эта эволюция дала дизайнеру больше контроля над внешним видом сайта за счет более сложного HTML. Вариации в веб-браузер реализации, такие как ВиолаWWW и Всемирная сеть,[27] усложняли единообразный внешний вид сайта, и у пользователей было меньше контроля над отображением веб-контента. Браузер / редактор, разработанный Тимом Бернерсом-Ли, имел таблицы стилей, жестко закодированные в программе. Поэтому таблицы стилей нельзя было связать с документами в Интернете.[23] Роберт Кайо, также из CERN, хотели отделить структуру от презентации, чтобы разные таблицы стилей могли описывать разные презентации для печати, экранных презентаций и редакторов.[27]

Улучшение возможностей веб-презентации было темой, интересующей многих в веб-сообществе, и девять различных языков таблиц стилей были предложены в списке рассылки в стиле www.[26] Из этих девяти предложений два особенно повлияли на то, что стало CSS: каскадные таблицы стилей HTML.[22] и Предложение таблицы стилей на основе потока (SSP).[25][28] Два браузера служили тестовыми площадками для первоначальных предложений; Ли работал с Ив Лафон внедрить CSS в Дэйв Рэггетт с Арена браузер.[29][30][31] Берт Бос реализовал свое собственное предложение SSP в Арго браузер.[25] После этого Ли и Бос работали вместе над разработкой стандарта CSS (буква «H» была удалена из названия, поскольку эти таблицы стилей также можно было применять к другим языкам разметки помимо HTML).[23]

Предложение Ли было представлено на "Мозаика и Интернет конференция (позже названная WWW2) в Чикаго, штат Иллинойс, в 1994 году, и снова с Бертом Босом в 1995 году.[23] Примерно в это время уже создавался W3C, который интересовался развитием CSS. С этой целью был организован семинар под председательством Стивен Пембертон. Это привело к тому, что W3C добавил работу над CSS к результатам работы редакционной комиссии HTML (ERB). Ли и Бос были основным техническим персоналом по этому аспекту проекта, с дополнительными членами, включая Томас Рирдон компании Microsoft, также участвующей. В августе 1996 г. Netscape Communication Corporation представил альтернативный язык таблиц стилей под названием Таблицы стилей JavaScript (JSSS).[23] Спецификация так и не была завершена и устарела.[32] К концу 1996 года CSS был готов стать официальным, и в декабре была опубликована рекомендация CSS уровня 1.

Разработка HTML, CSS и ДОМ все это происходило в одной группе, Редакционной коллегии HTML (ERB). В начале 1997 года Еврорадио было разделено на три рабочие группы: Рабочая группа HTML под председательством Дэн Коннолли W3C; Рабочая группа DOM под председательством Лорен Вуд из SoftQuad; и CSS рабочая группа под председательством Крис Лилли из W3C.

Рабочая группа CSS начала заниматься проблемами, которые не были решены с помощью CSS уровня 1, в результате чего 4 ноября 1997 года был создан CSS уровня 2. 12 мая 1998 года он был опубликован как Рекомендация W3C. CSS уровня 3, который был начат в 1998 году, по состоянию на 2014 год все еще находится в стадии разработки.

В 2005 году рабочие группы CSS решили ужесточить требования к стандартам. Это означало, что уже опубликованные стандарты, такие как CSS 2.1, CSS 3 Selectors и CSS 3 Text, были перенесены с уровня Candidate Рекомендация на уровень рабочего проекта.

Трудности с усыновлением

Спецификация CSS 1 была завершена в 1996 году. Microsoft Internet Explorer 3[23] был выпущен в том же году с некоторой ограниченной поддержкой CSS. IE 4 и Netscape 4.x добавили дополнительную поддержку, но обычно она была неполной и имела много ошибки это помешало использованию CSS. Прошло более трех лет, прежде чем какой-либо веб-браузер достиг почти полной реализации спецификации. Internet Explorer 5.0 для Macintosh, выпущенный в марте 2000 года, был первым браузером, имеющим полную (лучше 99 процентов) поддержку CSS 1,[33] превосходящий Опера, который был лидером с момента внедрения поддержки CSS пятнадцатью месяцами ранее. Вскоре последовали и другие браузеры, и многие из них дополнительно реализовали части CSS 2.[нужна цитата ]

Однако даже когда браузеры более поздней версии 5 начали предлагать довольно полную реализацию CSS, они все еще были некорректны в определенных областях и были чреваты несоответствиями, ошибками и прочим. причуды. Microsoft Internet Explorer 5.x для Windows, в отличие от очень разных IE для Macintosh, имела некорректную реализацию 'Модель коробки CSS 'по сравнению со стандартами CSS. Такие несоответствия и различия в поддержке функций мешали дизайнерам добиться единообразия внешнего вида в браузерах и платформы без использования обходные пути названный CSS-хаки и фильтры. Ошибки блочной модели IE / Windows были настолько серьезными, что когда Internet Explorer 6 был выпущен, Microsoft представила обратно совместимый режим интерпретации CSS ('режим причуд ') вместе с альтернативным, исправленным "стандартным режимом". Другие браузеры сторонних производителей также предоставляют такую ​​возможность переключения режимов. Поэтому у авторов HTML файлы, чтобы убедиться, что они содержат особые отличительные маркер "соответствующий стандартам CSS" чтобы показать, что авторы предполагали, что CSS будет интерпретироваться правильно, в соответствии со стандартами, а не для давно устаревших IE5 / браузер Windows. Без этого маркера веб-браузеры, у которых есть возможность переключения режима причуд, будут изменять размеры объектов на веб-страницах, как IE5 / Windows, вместо того, чтобы следовать стандартам CSS.[нужна цитата ]

Проблемы с неоднородным внедрением CSS, наряду с ошибками в исходной спецификации, вынудили W3C пересмотреть стандарт CSS 2 в CSS 2.1, который приблизился к рабочему снимку текущей поддержки CSS в браузерах HTML. Некоторые свойства CSS 2, которые ни один браузер не реализовал, были отброшены, а в некоторых случаях определенное поведение было изменено, чтобы привести стандарт в соответствие с преобладающими существующими реализациями. CSS 2.1 стал кандидатом в рекомендации 25 февраля 2004 г., но CSS 2.1 был возвращен в статус рабочего проекта 13 июня 2005 г.[34] и вернулся в статус кандидата в рекомендации только 19 июля 2007 г.[35]

Помимо этих проблем, .css расширение использовалось программным продуктом для преобразования Силовая установка файлы в файлы компактных слайд-шоу,[36]поэтому некоторые веб-серверы обслуживали все .css[37] так как Тип MIME приложение / x-pointplus[38] скорее, чем текст / css.

Вариации

CSS имеет разные уровни и профили. Каждый уровень CSS основывается на последнем, обычно добавляя новые функции и обычно обозначаемый как CSS 1, CSS 2, CSS 3 и CSS 4. Профили обычно представляют собой подмножество одного или нескольких уровней CSS, созданных для конкретного устройства или пользовательского интерфейса. . На данный момент существуют профили для мобильных устройств, принтеров и телевизоров. Профили не следует путать с типами мультимедиа, которые были добавлены в CSS 2.

CSS 1

Первая спецификация CSS, которая стала официальной рекомендацией W3C, - это CSS уровня 1, опубликованная 17 декабря 1996 года. Хокон Виум Ли и Берт Бос указаны как оригинальные разработчики.[39][40] Среди его возможностей - поддержка

  • Шрифт такие свойства, как шрифт и выделение
  • Цвет текста, фона и других элементов
  • Атрибуты текста, такие как интервал между словами, буквами и строками текста
  • Выравнивание текста, изображений, столы и другие элементы
  • Поля, граница, отступы и позиционирование для большинства элементов
  • Уникальная идентификация и общая классификация групп атрибутов

W3C больше не поддерживает Рекомендацию CSS 1.[41]

CSS 2

Спецификация CSS уровня 2 была разработана W3C и опубликована как рекомендация в мае 1998 года. Надмножество CSS 1, CSS 2 включает ряд новых возможностей, таких как абсолютное, относительное и фиксированное позиционирование элементов и z-индекс, концепция типов мультимедиа, поддержка звуковых таблиц стилей (которые позже были заменены речевыми модулями CSS 3)[42] и двунаправленный текст, и новые свойства шрифта, такие как тени.

W3C больше не поддерживает рекомендацию CSS 2.[43]

CSS 2.1

Версия 1 CSS уровня 2, часто называемая «CSS 2.1», исправляет ошибки в CSS 2, удаляет плохо поддерживаемые или не полностью совместимые функции и добавляет в спецификацию уже реализованные расширения браузера. Чтобы соответствовать процессу W3C стандартизации технических спецификаций, CSS 2.1 много лет перемещался между статусом рабочего проекта и статусом кандидата в рекомендации. CSS 2.1 сначала стал Кандидат в рекомендации 25 февраля 2004 г., но 13 июня 2005 г. он был преобразован в рабочий проект для дальнейшего рассмотрения. Он вернулся в Рекомендацию кандидата 19 июля 2007 года, а затем дважды обновился в 2009 году. Однако, поскольку были внесены изменения и разъяснения, он снова вернулся в Рабочий проект последнего объявления 7 декабря 2010 года.

CSS 2.1 перешел к Предложенной рекомендации 12 апреля 2011 г.[44] После рассмотрения Консультативным комитетом W3C, 7 июня 2011 года он был наконец опубликован как Рекомендация W3C.[45]

CSS 2.1 планировался как первая и последняя редакция уровня 2, но в 2015 году началась низкоприоритетная работа над CSS 2.2.

CSS 3

В отличие от CSS 2, который представляет собой большую единую спецификацию, определяющую различные функции, CSS 3 разделен на несколько отдельных документов, называемых «модулями». Каждый модуль добавляет новые возможности или расширяет функции, определенные в CSS 2, с сохранением обратной совместимости. Работа над уровнем CSS 3 началась примерно во время публикации исходной рекомендации CSS 2. Самые ранние черновики CSS 3 были опубликованы в июне 1999 г.[46]

Из-за модульности разные модули имеют разную стабильность и статусы.[47]

Некоторые модули имеют Кандидат в рекомендации (CR) статус и считаются умеренно стабильными. В CR На этапе реализации рекомендуется отказаться от префиксов поставщиков.[48]

Краткое изложение основных характеристик модуля[49]
МодульНазвание спецификацииПоложение делДата
css3-фонCSS-фоны и границы, уровень 3  Кандидат Рек.Октябрь 2017
css3-коробкаБазовая блочная модель CSSЗа работой ПроектИюл 2018
css-каскад-3Каскадирование и наследование CSS, уровень 3  Кандидат Рек.Май 2016
css3-цветЦветовой модуль CSS, уровень 3РекомендацияИюн 2018
css3-контентМодуль сгенерированного и замененного содержимого CSS3  За работой ПроектИюн 2016
css-шрифты-3Модуль CSS Fonts Уровень 3РекомендацияСен 2018
css3-gcpmСозданный CSS контент для страничного медиа-модуляЗа работой ПроектМай 2014 г.
css3-макетМодуль макета шаблона CSSПримечаниеМарт 2015 г.
css3-mediaqueries Медиа-запросыРекомендацияИюн 2012
mediaqueries-4 Медиа-запросы, уровень 4Кандидат Рек.Сен 2017
css3-мультикол Модуль макета с несколькими столбцами, уровень 1За работой ПроектМай 2018
css3-страницаCSS Страничный медиа-модуль, уровень 3За работой ПроектМарт 2013 г.
селекторы-3Селекторы уровня 3РекомендацияНоя 2018
селекторы-4Селекторы уровня 4За работой ПроектФевраль 2018 г.
css3-uiМодуль базового пользовательского интерфейса CSS, уровень 3 (CSS3 UI)РекомендацияИюн 2018

CSS 4

Джен Симмонс обсуждая состояние CSS в 2019 году, как несколько CSS 4 модуля в стадии разработки

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

Модули, основанные на элементах CSS уровня 2, начались на уровне 3. Некоторые из них уже достигли уровня 4 или уже приближаются к уровню 5. Другие модули, которые определяют совершенно новые функции, такие как Flexbox,[51] были определены как Уровень 1, а некоторые из них приближаются к Уровню 2.

Рабочая группа CSS иногда публикует «Снимки состояния», совокупность целых модулей и частей других проектов, которые считаются достаточно стабильными для реализации разработчиками браузеров. На данный момент пять таких документов о «передовой текущей практике» были опубликованы в виде заметок в 2007 г.[52] 2010,[53] 2015,[54] 2017,[55] и 2018.[56]

Поскольку эти снимки спецификаций в первую очередь предназначены для разработчиков, растет спрос на аналогичный справочный документ с версией, ориентированный на авторов, который будет представлять состояние совместимых реализаций, как тем временем документировано такими сайтами, как Can I Use…[57] и сеть разработчиков Mozilla.[58] Группа сообщества W3C была создана в начале 2020 года для обсуждения и определения такого ресурса.[59] Фактический вид управление версиями также является предметом обсуждения, а это означает, что однажды созданный документ может не называться «CSS4».

Поддержка браузера

Каждый веб-браузер использует механизм компоновки для отображения веб-страниц, и поддержка функциональности CSS между ними не согласована. Поскольку браузеры не анализируют CSS идеально, было разработано несколько методов кодирования, предназначенных для конкретных браузеров с помощью обходных путей (обычно известных как CSS-хаки или фильтры CSS). Принятию новых функций в CSS может помешать отсутствие поддержки в основных браузерах. Например, Internet Explorer не спешил добавлять поддержку многих функций CSS 3, что замедляло внедрение этих функций и наносило ущерб репутации браузера среди разработчиков.[60] Чтобы обеспечить единообразие взаимодействия с пользователями, веб-разработчики часто тестируют свои сайты в разных операционных системах, браузерах и версиях браузеров, что увеличивает время и сложность разработки. Такие инструменты как BrowserStack были созданы, чтобы упростить обслуживание этих сред.

В дополнение к этим инструментам тестирования многие сайты поддерживают списки поддержки браузерами определенных свойств CSS, включая Могу ли я использовать и Сеть разработчиков Mozilla. Кроме того, CSS 3 определяет запросы функций, которые обеспечивают @supports директива, которая позволит разработчикам настраивать таргетинг на браузеры с поддержкой определенных функций непосредственно в их CSS.[61] CSS, который не поддерживается старыми браузерами, также иногда можно исправить с помощью JavaScript. полифиллы, которые представляют собой фрагменты кода JavaScript, предназначенные для обеспечения согласованного поведения браузеров. Эти обходные пути - а также необходимость поддержки резервных функций - могут усложнить проекты разработки, и, следовательно, компании часто определяют список версий браузеров, которые они будут и не будут поддерживать.

Поскольку веб-сайты принимают новые стандарты кода, несовместимые со старыми браузерами, эти браузеры могут быть отключены от доступа ко многим ресурсам в Интернете (иногда намеренно).[62] Многие из самых популярных сайтов в Интернете не только визуально ухудшаются в старых браузерах из-за плохой поддержки CSS, но и вообще не работают, в значительной степени из-за развития JavaScript и других веб-технологий.

Ограничения

Некоторые отмеченные ограничения текущих возможностей CSS включают:

Селекторы не могут подняться
CSS в настоящее время не предлагает возможности выбрать родитель или предок элемента, удовлетворяющего определенным критериям.[63] CSS Selectors Level 4, который все еще находится в статусе рабочего проекта, предлагает такой селектор,[64] но только как часть «полного» профиля селектора, а не «быстрого» профиля, используемого в динамических стилях CSS.[65] Более продвинутая схема выбора (например, XPath ) позволит использовать более сложные таблицы стилей. Основные причины, по которым рабочая группа CSS ранее отклоняла предложения по родительским селекторам, связаны с производительностью браузера и инкрементный рендеринг проблемы.[66]
Невозможно явно объявить новую область видимости независимо от позиции
Правила области действия для свойств, таких как z-index, ищут ближайший родительский элемент с атрибутом position: absolute или position: relative. Эта странная связь имеет нежелательные эффекты. Например, невозможно избежать объявления новой области видимости, когда кто-то вынужден корректировать положение элемента, не позволяя использовать желаемую область видимости родительского элемента.
Неуправляемое динамическое поведение псевдокласса
CSS реализует псевдоклассы, которые позволяют получать обратную связь с пользователем путем условного применения альтернативных стилей. Один псевдокласс CSS ":парить", является динамическим (эквивалент JavaScript" onmouseover ") и потенциально может быть использован неправильно (например, реализация всплывающих окон рядом с курсором),[67] но CSS не имеет возможности для клиента отключить его (нет свойства типа «отключить») или ограничить его эффекты (нет значений типа «без изменения» для каждого свойства).
Не могу назвать правила
Невозможно назвать правило CSS, которое позволило бы (например) клиентским скриптам ссылаться на правило, даже если его селектор изменится.
Невозможно включить стили из правила в другое правило
Стили CSS часто должны дублироваться в нескольких правилах для достижения желаемого эффекта, что вызывает дополнительное обслуживание и требует более тщательного тестирования. Для решения этой проблемы были предложены некоторые новые функции CSS, но впоследствии от них отказались.[68][69]
Невозможно настроить таргетинг на конкретный текст без изменения разметки
Кроме :первое письмо псевдоэлемент, нельзя настроить таргетинг на определенные диапазоны текста без использования элементов-заполнителей.

Бывшие проблемы

Кроме того, в предыдущих версиях стандарта CSS присутствовало еще несколько проблем, но они были устранены:

Ограничения вертикального контроля
Хотя горизонтальное размещение элементов всегда было легко контролировать, вертикальное размещение часто было не интуитивно понятным, запутанным или совершенно невозможным. Простые задачи, такие как центрирование элемента по вертикали или размещение нижнего колонтитула не выше нижней части области просмотра, требовали либо сложных и неинтуитивных правил стиля, либо простых, но широко не поддерживаемых правил.[63] Модуль Flexible Box Module значительно улучшил ситуацию, а вертикальное управление стало намного проще и поддерживается во всех современных браузерах.[70] В старых браузерах все еще есть эти проблемы, но большинство из них (в основном Internet Explorer 9 и ниже) больше не поддерживаются их поставщиками.[71]
Отсутствие выражений
Не было стандартной возможности задавать значения свойств в виде простых выражений (таких как маржа слева: 10% 3em + 4 пикселя;). Это было бы полезно во множестве случаев, например, при вычислении размера столбцов с учетом ограничения на сумму всех столбцов. Internet Explorer версий с 5 по 7 поддерживает собственный оператор выражения (),[72] с аналогичным функционалом. Этот проприетарный оператор expression () больше не поддерживается начиная с Internet Explorer 8, за исключением режимов совместимости. Это решение было принято из соображений "соответствия стандартам, производительности браузера и безопасности".[72] Однако рекомендация кандидата со значением calc () для устранения этого ограничения было опубликовано рабочей группой CSS[73] и с тех пор поддерживается во всех современных браузерах.[74]
Отсутствие объявления столбца
Хотя это возможно в текущем CSS 3 (с использованием счетчик столбцов модуль),[75] макеты с несколькими столбцами могут быть сложными для реализации в CSS 2.1. В CSS 2.1 процесс часто выполняется с использованием плавающих элементов, которые часто по-разному отображаются в разных браузерах, разных формах экрана компьютеров и разных соотношениях экрана, установленных на стандартных мониторах. Все современные браузеры в той или иной форме поддерживают эту функцию CSS 3.[76]

Преимущества

Отделение контента от презентации
CSS упрощает публикацию контента в нескольких форматах представления на основе номинальных параметров. Номинальные параметры включают явные предпочтения пользователя, различные веб-браузеры, тип устройства, используемого для просмотра контента (настольный компьютер или мобильное устройство), географическое местоположение пользователя и многие другие переменные.
Согласованность по всему сайту
Когда CSS используется эффективно, с точки зрения наследования и «каскадирования», глобальная таблица стилей может использоваться для изменения и стилизации элементов в масштабе всего сайта. Если возникает ситуация, когда стиль элементов должен быть изменен или скорректирован, эти изменения могут быть внесены путем редактирования правил в глобальной таблице стилей. До появления CSS подобное обслуживание было более сложным, дорогим и трудоемким.
Пропускная способность
Таблица стилей, внутренняя или внешняя, определяет стиль один раз для диапазона элементов HTML, выбранных класс, тип или отношение к другим. Это намного эффективнее, чем повторение информации о стиле в строке для каждого вхождения элемента. Внешняя таблица стилей обычно хранится в кеш браузера, и поэтому его можно использовать на нескольких страницах без перезагрузки, что еще больше сокращает передачу данных по сети.
Переформатирование страницы
Простым изменением одной строки можно использовать другую таблицу стилей для той же страницы. Это дает преимущества для доступности, а также дает возможность адаптировать страницу или сайт к различным целевым устройствам. Более того, устройства, не способные понять стиль, по-прежнему отображают контент.
Доступность
Без CSS веб-дизайнеры обычно должны размещать свои страницы с помощью таких приемов, как таблицы HTML, которые затрудняют доступность для пользователей с ослабленным зрением (см. Веб-дизайн без стола # Доступность ).

Стандартизация

Каркасы

CSS-фреймворки заранее подготовлены библиотеки которые предназначены для облегчения, большего соответствующий стандартам стиль веб-страница с использованием языка каскадных таблиц стилей. CSS-фреймворки включают Чертеж, Бутстрап, Каскадная структура, Фонд и материализоваться. Как и библиотеки языков программирования и сценариев, CSS-фреймворки обычно включаются в виде внешних листов .css, на которые есть ссылки в HTML. <голова>. Они предоставляют ряд готовых вариантов дизайна и верстки веб-страницы. Хотя многие из этих фреймворков были опубликованы, некоторые авторы используют их в основном для быстрого создания прототипов или для обучения, и предпочитают «вручную создавать» CSS, который подходит для каждого опубликованного сайта, без дополнительных затрат на проектирование, обслуживание и загрузку из-за наличия множества неиспользуемых функций. в стилистике сайта.[77]

Методики проектирования

По мере увеличения размера ресурсов CSS, используемых в проекте, команде разработчиков часто приходится выбирать общую методологию проектирования, чтобы поддерживать их организованность. Целями являются простота разработки, простота совместной работы во время разработки и производительность развернутых таблиц стилей в браузере. Популярные методологии включают OOCSS (объектно-ориентированный CSS), ACSS (атомарный CSS), oCSS (органическая каскадная таблица стилей), SMACSS (масштабируемая и модульная архитектура для CSS) и BEM (блок, элемент, модификатор).[78]

использованная литература

  1. ^ «Руководство разработчика CSS». Сеть разработчиков Mozilla. В архиве из оригинала от 25.09.2015. Получено 2015-09-24.
  2. ^ Фланаган, Дэвид. JavaScript - подробное руководство (6 изд.). п. 1. JavaScript является частью триады технологий, которую должны изучить все веб-разработчики: HTML для определения содержимого веб-страниц, CSS для определения представления веб-страниц и JavaScript для определения поведения веб-страниц.
  3. ^ "Что такое CSS?". Консорциум World Wide Web. В архиве из оригинала от 29.11.2010. Получено 2010-12-01.
  4. ^ «Мобильные веб-приложения будущего с использованием HTML 5, CSS и JavaScript». HTMLGoodies. В архиве с оригинала на 2014-10-20. Получено 2014-10-16.
  5. ^ «Служба проверки CSS W3C». В архиве из оригинала от 14.02.2011. Получено 2012-06-30.
  6. ^ «Спецификация W3C CSS2.1 для псевдоэлементов и псевдоклассов». Консорциум World Wide Web. 7 июня 2011 г. В архиве из оригинала 30 апреля 2012 г.. Получено 30 апреля 2012.
  7. ^ увидеть полное определение селекторов на веб-сайте W3C В архиве 2006-04-23 на Wayback Machine.
  8. ^ «Селекторы 3-го уровня». W3.org. В архиве из оригинала от 03.06.2014. Получено 2014-05-30.
  9. ^ «Спецификация W3C CSS2.1 для наборов правил, блоков объявлений и селекторов». Консорциум World Wide Web. 7 июня 2011 г. В архиве из оригинала 28 марта 2008 г.. Получено 2009-06-20.
  10. ^ «Полная таблица свойств». W3.org. В архиве из оригинала 30.05.2014. Получено 2014-05-30.
  11. ^ «Указатель свойств CSS». www.w3.org. Получено 2020-08-09.
  12. ^ "Цвет CSS". Сеть разработчиков Mozilla. 2016-06-28. В архиве из оригинала от 21.09.2016. Получено 2016-08-23.
  13. ^ «6.1 Единицы длины». Каскадные таблицы стилей, уровень 1. 17 декабря 1996 г. В архиве из оригинала 14 июня 2019 г.. Получено 20 июн 2019.
  14. ^ "5. Единицы измерения расстояния: тип <длина>". Модуль значений и единиц CSS, уровень 3. 6 июня 2019. В архиве из оригинала 7 июня 2019 г.. Получено 20 июн 2019.
  15. ^ Рабочая группа W3C HTML. «HTML 5. Словарь и связанные API для HTML и XHTML». Консорциум World Wide Web. В архиве из оригинала 15 июля 2014 г.. Получено 28 июн 2014.
  16. ^ а б Мейер, Эрик А. (2006). Каскадные таблицы стилей: полное руководство (3-е изд.). O'Reilly Media, Inc. ISBN  0-596-52733-0. В архиве из оригинала от 15.02.2014. Получено 2014-02-16.
  17. ^ «Присвоение значений свойств, каскадирование и наследование». В архиве из оригинала на 2014-06-11. Получено 2014-06-10.
  18. ^ «Может ли класс CSS наследовать один или несколько других классов?». Переполнение стека. В архиве с оригинала на 2017-10-14. Получено 2017-09-10.
  19. ^ «Сокращенные свойства». Руководство. Разработчики Mozilla. 2017-12-07. Архивировано из оригинал на 2018-01-30. Получено 2018-01-30.
  20. ^ а б c Бос, Берт; и другие. (7 декабря 2010 г.). «9.3 Схемы позиционирования». Спецификация каскадных таблиц стилей, уровень 2, редакция 1 (CSS 2.1). W3C. В архиве из оригинала 18 февраля 2011 г.. Получено 16 февраля 2011.
  21. ^ Holzschlag, Молли Э (2005). Погрузитесь в HTML и CSS. Pearson Education, Inc. ISBN  0-13-185586-7.
  22. ^ а б Ли, Хакон В. (10 октября 1994 г.). «Каскадные таблицы стилей HTML - предложение» (Предложение) (92). ЦЕРН. В архиве из оригинала от 4 июня 2014 г.. Получено 25 мая 2014. Цитировать журнал требует | журнал = (Помогите)
  23. ^ а б c d е ж Ли, Хокон Виум; Бос, Берт (1999). Каскадные таблицы стилей, разработка для Интернета. Эддисон Уэсли. ISBN  0-201-59625-3. Получено 23 июн 2010.
  24. ^ «Каскадные таблицы стилей, уровень 1». Консорциум World Wide Web. В архиве из оригинала от 09.04.2014. Получено 2014-03-07.
  25. ^ а б c Бос, Берт (14 апреля 1995 г.). «Простые таблицы стилей для SGML и HTML в Интернете». Консорциум World Wide Web. В архиве из оригинала 23 сентября 2009 г.. Получено 20 июн 2010.
  26. ^ а б c «Каскадные таблицы стилей». Университет Осло. Архивировано из оригинал на 2006-09-06. Получено 3 сентября 2014.
  27. ^ а б Петри, Чарльз; Кайо, Роберт (Ноябрь 1997 г.). »Интервью Роберта Кайо о предложении WWW:« Как это на самом деле произошло »."". Институт инженеров по электротехнике и электронике. Архивировано из оригинал 6 января 2011 г.. Получено 18 августа 2010.
  28. ^ Бос, Берт (31 марта 1995 г.). «Предложение таблицы стилей на основе потока». В архиве из оригинала 12 октября 2014 г.. Получено 3 сентября 2014.
  29. ^ Нильсен, Хенрик Фристик (7 июня 2002 г.). "Libwww Hackers". Консорциум World Wide Web. В архиве из оригинала от 2 декабря 2009 г.. Получено 6 июн 2010.
  30. ^ "Ив Лафон". Консорциум World Wide Web. В архиве из оригинала 24 июня 2010 г.. Получено 17 июн 2010.
  31. ^ «Команда W3C: технологии и общество». Консорциум World Wide Web. 18 июля 2008 г. В архиве из оригинала 28 мая 2010 г.. Получено 22 января 2011.
  32. ^ Лу Монтулли; Брендан Эйх; Скотт Фурман; Донна Конверс; Трой Шевалье (22 августа 1996 г.). «Таблицы стилей на основе JavaScript». W3C. В архиве из оригинала 27 мая 2010 г.. Получено 23 июн 2010.
  33. ^ «Программное обеспечение CSS». W3.org. В архиве из оригинала 25.11.2010. Получено 2011-01-15.
  34. ^ Энн ван Кестерен. "CSS 2.1 - блог Анны". В архиве с оригинала от 10.12.2005. Получено 2011-02-16.
  35. ^ «Архив новостей W3C за 2007 год». Консорциум World Wide Web. В архиве из оригинала 2011-06-28. Получено 2011-02-16.
  36. ^ Нитот, Тристан (18 марта 2002 г.). «Неверный тип MIME для файлов CSS». Центр разработчиков Mozilla. Mozilla. Архивировано из оригинал на 2011-05-20. Получено 20 июн 2010.
  37. ^ Макбрайд, Дон (27 ноября 2009 г.). "Типы файлов". В архиве из оригинала 29 октября 2010 г.. Получено 20 июн 2010.
  38. ^ "Детали расширения файла css". База данных расширений файлов. 12 марта 2010. Архивировано с оригинал 18 июля 2011 г.. Получено 20 июн 2010.
  39. ^ Бос, / Хокон Виум Ли, Берт (1997). Каскадные таблицы стилей: проектирование для Интернета (1-е изд.). Харлоу, Англия; Ридинг, Массачусетс: Эддисон Уэсли Лонгман. ISBN  0-201-41998-X.
  40. ^ W3C: Каскадные таблицы стилей, уровень 1 В архиве 2011-02-09 в Wayback Machine Спецификация CSS 1
  41. ^ W3C: Спецификация каскадных таблиц стилей уровня 1 В архиве 2011-02-11 в Wayback Machine Спецификация CSS уровня 1
  42. ^ «Таблицы стилей на слух». W3C. В архиве с оригинала от 26.10.2014. Получено 2014-10-26.
  43. ^ W3C: Каскадные таблицы стилей, уровень 2 В архиве 2011-01-16 на Wayback Machine Спецификация CSS 2 (рекомендация 1998 г.)
  44. ^ W3C:Каскадные таблицы стилей, уровень 2, редакция 1 В архиве 2011-11-09 в Wayback Machine Спецификация CSS 2.1 (предлагаемая рекомендация W3C)
  45. ^ W3C: Стандарт каскадных таблиц стилей отличается беспрецедентной совместимостью В архиве 2011-06-10 на Wayback Machine
  46. ^ Бос, Берт (18 февраля 2011 г.). «Описание всех спецификаций CSS». Консорциум World Wide Web. В архиве из оригинала 31 марта 2011 г.. Получено 3 марта 2011.
  47. ^ Бос, Берт (26 февраля 2011 г.). "Текущая работа CSS". Консорциум World Wide Web. В архиве из оригинала 3 марта 2011 г.. Получено 3 марта 2011.
  48. ^ Этемад, Элика Дж. (12 декабря 2010 г.). «Снимок каскадных таблиц стилей (CSS) 2010». Консорциум World Wide Web. В архиве из оригинала 16 марта 2011 г.. Получено 3 марта 2011.
  49. ^ «Все спецификации CSS». W3.org. 2014-05-22. В архиве из оригинала 30.05.2014. Получено 2014-05-30.
  50. ^ Аткинс-младший, табл. «Несколько слов о CSS4». В архиве из оригинала 31 октября 2012 г.. Получено 18 октября 2012.
  51. ^ "Модуль макета гибкого блока CSS, уровень 1". W3C. 19 ноября 2018. В архиве из оригинала 19 октября 2012 г.. Получено 18 октября 2012.
  52. ^ «Снимок каскадных таблиц стилей (CSS) 2007». 12 мая 2011 г. В архиве из оригинала от 8 августа 2016 г.. Получено 18 июля 2016.
  53. ^ «Снимок каскадных таблиц стилей (CSS) 2010». 12 мая 2011 г. В архиве из оригинала 16 марта 2011 г.. Получено 3 марта 2011.
  54. ^ «CSS Snapshot 2015». W3C. 13 октября 2015 г. В архиве из оригинала 27 января 2017 г.. Получено 13 февраля 2017.
  55. ^ «Снимок CSS 2017». 31 января 2017. В архиве из оригинала 13 февраля 2017 г.. Получено 13 февраля 2017.
  56. ^ «Снимок CSS 2018». 15 ноября 2018. В архиве с оригинала на 1 февраля 2019 г.. Получено 2 января 2019.
  57. ^ «Могу ли я использовать… Поддержка таблиц для HTML5, CSS3 и т. Д.». В архиве из оригинала на 2018-02-19. Получено 2019-01-26.
  58. ^ "Веб-документы MDN: CSS".
  59. ^ "Группа сообщества CSS4". В архиве из оригинала 27.02.2020. Получено 2020-02-27.
  60. ^ «Решения CSS3 для Internet Explorer - Smashing Magazine». Smashing Magazine. 2010-04-28. В архиве из оригинала на 2016-10-12. Получено 2016-10-12.
  61. ^ «Использование запросов функций в CSS ★ Mozilla Hacks - блог веб-разработчиков». hacks.mozilla.org. В архиве из оригинала на 2016-10-11. Получено 2016-10-12.
  62. ^ «Последний раз заглянул в Интернет с помощью Internet Explorer 6». Ars Technica. В архиве из оригинала на 2016-10-12. Получено 2016-10-12.
  63. ^ а б Молли Хольцшлаг (Январь 2012 г.). «Семь вещей, которые все еще отсутствуют в CSS». .net Журнал. Архивировано из оригинал на 2017-03-05. Получено 2017-03-04.
  64. ^ «Селекторы уровня 4 - Определение предмета селектора». W3.org. В архиве из оригинала от 17.08.2013. Получено 2013-08-13.
  65. ^ «Селекторы уровня 4 - быстрые или полные профили селектора». W3.org. В архиве из оригинала от 17.08.2013. Получено 2013-08-13.
  66. ^ Снук, Джонатан (октябрь 2010 г.). «Почему у нас нет родительского селектора». snook.ca. Архивировано из оригинал на 2012-01-18. Получено 2012-01-26.
  67. ^ "Всплывающие окна на чистом CSS". meyerweb.com. Архивировано из оригинал на 2009-12-09. Получено 2009-11-19.
  68. ^ Таб Аткинс младший «Правило применения CSS». GitHub. Архивировано из оригинал на 2016-02-22. Получено 2016-02-27.
  69. ^ https://www.xanthir.com/b4o00
  70. ^ "Модуль макета гибкого блока CSS". Могу ли я использовать ... Таблицы поддержки HTML5, CSS3 и т. Д.. CanIUse.com. Архивировано из оригинал 23 февраля 2016 г.
  71. ^ «Окончание поддержки Internet Explorer». Microsoft. В архиве из оригинала на 2019-06-02. Получено 2016-02-27.
  72. ^ а б «О динамических свойствах». Msdn.microsoft.com. Архивировано из оригинал на 2017-10-14. Получено 2009-06-20.
  73. ^ «Модуль значений и единиц CSS, уровень 3». W3.org. 6 июня 2019. В архиве из оригинала от 23 апреля 2008 г.
  74. ^ "calc () как значение единицы CSS". Могу ли я использовать ... Таблицы поддержки HTML5, CSS3 и т. Д.. CanIUse.com. Архивировано из оригинал на 2016-03-04.
  75. ^ "Модуль макета с несколькими столбцами CSS". Консорциум World Wide Web. В архиве из оригинала 2011-04-29. Получено 2011-05-01.
  76. ^ «Могу ли я использовать ... Поддерживающие таблицы для HTML5, CSS3 и т. Д.». CanIUse.com. Архивировано из оригинал на 21.08.2010. Получено 2016-02-27.
  77. ^ Седерхольм, Дэн; Итан Маркотт (2009). Ручной CSS: более надежный веб-дизайн. Новые всадники. п. 114. ISBN  978-0-321-64338-4. В архиве из оригинала от 20 декабря 2012 г.. Получено 19 июн 2010.
  78. ^ Антти, Хиля. «OOCSS, ACSS, BEM, SMACSS: что это такое? Что мне использовать?». clubmate.fi. Hiljá. Архивировано из оригинал 2 июня 2015 г.. Получено 2 июн 2015.

дальнейшее чтение

внешняя ссылка