Расширение имени файла | .css |
---|---|
Тип Интернет -носителя | text / 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. CSS - это краеугольная технология World Wide Web, включая HTML и JavaScript.
CSS для создания представления и содержимого, включая макет, цвета и шрифты. Такое разделение может улучшить доступность контента, большую гибкость и контроль при представлении, позволяет нескольким веб-страницам совместно использовать форматирование, указав соответствующий CSS в отдельном файле.css, который уменьшает сложность и повторение структурного содержимого, а также позволяет кэшировать файл.css, чтобы повысить скорость загрузки страниц между страницами, которые используют файл, и его форматирование.
Разделение форматирования и содержимого также позволяет одну и ту же страницу разметки в разных стилях для разных методов визуализации, в печати, голосом (через браузер на основе речи или программа чтения с экрана ) и на тактильных устройствах на основе шрифта Брайля. В CSS также есть правила альтернативного форматирования, если доступ к контенту осуществляется на мобильном устройстве.
. Каскадирование имен происходит из определенных схем приоритета, чтобы определить, какое правило стиля применяется, если более одного правила соответствует определенному элементу. Эта каскадная схема приоритетов предсказуема.
Спецификации CSS поддерживаются Консорциумом Всемирной паутины (W3C). Тип Интернет-носителя (MIME-тип ) text / css
зарегистрирован для использования с CSS в RFC 2318 (март 1998 г.). W3C предоставляет бесплатную службу проверки CSS для документов CSS.
В дополнение к HTML, другие языки разметки использования CSS, включая XHTML, plain XML, SVG и XUL.
CSS имеет простой синтаксис слов и использует несколько английских ключевых ключевых слов для указаний имена разных стилей свойства.
Таблица стилей состоит из списка правил. Каждое правило или набор правил состоит из одного или нескольких селекторов и блока объявления.
В CSS-селекторы объявляют, к каким частям разметки применяют стиль, путем сопоставления тегов и атрибутов в самой разметке.
Селекторы могут применяться к следующему:
Классы и коды чувствительны к регистру, начинаются с букв и могут быть буквенно-цифровые символы, дефисы и подчеркивания. Класс может использовать к любому количеству экземпляров любых элементов. ID может быть применен только к одному элементу.
Псевдоклассы используются в селекторах CSS, чтобы разрешить форматирование на основе информации, не содержащейся в дереве документа. Одним из примеров широко используемого псевдокласса является : hover
, который идентифицирует контент только тогда, когда пользователь «указывает» на видимый элемент, обычно удерживая курсор мыши над ним. Он добавляется к селектору, как в a: hover
или #elementid: hover
. Псевдокласс классифицирует элементы документа, такие как : ссылка
или : посещенный
, тогда как псевдоэлемент делает выбор, который может состоять из частичных элементов, таких как :: first-line
или :: первая буква
.
Селекторы можно комбинировать разными способами для достижения большей специфичности и гибкости. Несколько селекторов могут быть объединены в разнесенный список для определения элементов по местоположению, типу элемента, указатору, классу или любой их комбинации. Порядок селекторов важен. Например, div.myClass {color: red;}
использует ко всем элементам класса myClass, которые находятся внутри элементов div, тогда как .myClass div {color: red;}
применяемым ко всем элементы div, которые находятся в элементах класса myClass.
В этой таблице представлена сводка синтаксиса селектора с использованием и версией CSS.
Шаблон | Соответствует | Сначала определено. в CSS level |
---|---|---|
E | element типа E | 1 |
E: link | element E является исходным якорем гиперссылки, цель которой еще не посещена (: ссылка) или уже посещена (: посещена) | 1 |
E: активный | элемент E во время определенных действий пользователя | 1 |
E :: first-line | первая форматированная строка элемента E | 1 |
E :: первая буква | первая форматированная буква элемент E | 1 |
.c | все элементы с class = "c" | 1 |
#myid | элемент с id = "myid" | 1 |
E.warning | элемент E, класс - "предупреждение" (язык документа определяет, как определенный класс) | 1 |
E # myid | элемент E с указателем, равным "myid" | 1 |
.c # myid | с class = "c "и вычислительным, равным" myid " | 1 |
EF | элемент F, потомок элемента E | 1 |
* | любой элемент | 2 |
E [foo] | элемент E с атрибутом" foo " | 2 |
E [foo = "bar"] | и E элемент, значение атрибута "foo" которого точно равно "bar" | 2 |
E [foo ~ = "bar"] | элемент E, значение атрибута "foo" которого представляет собой список значений, разделенных пробелами, одно из которых в точности равно "bar" | 2 |
E [foo | = "ru"] | элемент E, атрибут "foo" которого содержит список значений, разделенных дефисами, начинающийся (слева) с "ru" | 2 |
E: first-child | элемент E, первый дочерний элемент его родительского | 2 |
E: lang (fr) | типа E на языке "fr" (язык документа указывает, как определенный язык) | 2 |
E :: before | сгенерированное содержимое перед содержимым элемента E | 2 |
E: : after | сгенерированное содержимое после содержимого элемента E | 2 |
E>F | дочерний элемент F элемента E element | 2 |
E + F | элемент F, который является внутренним предшествующим элементом E | 2 |
E [foo ^ = "bar"] | элемент E, значение атрибута "foo" которого начинается точно со строки "bar" | 3 |
E [foo $ = "bar"] | элемент E, значение атрибута "foo" которого заканчивается точно строкой "bar" | 3 |
E [foo * = "bar"] | элемент E, чей "f oo" значение атрибута содержит подстроку "bar" | 3 |
E: root | элемент E, корень документа | 3 |
E: nth-child (n) | элемент E, n-й дочерний элемент с воего родителя | 3 |
E: nth-last-child (n) | элемент E, n-й дочерний элемент своего родителя, считая от последнего | 3 |
E: nth-of-type (n) | элемент E, n-й брат своего типа | 3 |
E: nth-last-of-type (n) | элемент E, n-й брат своего типа, считая от последнего одного | 3 |
E: last-child | элемент E, последний дочерний элемент его родительского | 3 |
E: первый по типу | E элемент, первый брат его типа | 3 |
E: последний по типу | элемент E, последний родственник его типа | 3 |
E: only-child | элемент E, единственный дочерний элемент его родительского | 3 |
E: only-of-type | элемент E, только брат своего типа | 3 |
E: пустой | элемент E, не имеющий дочерних элементов (включая текстовые узлы) | 3 |
E: target | E, являющийся элементом которым целью рассматриваемого URI | 3 |
E: включен | пользовательского элемента интерфейса E, включен | 3 |
E: отключен | элемент пользовательского интерфейса E, который отключен в состоянии | 3 |
E: отмечен | элемент пользовательского интерфейса E, к оторый отмечен (например, радио-кнопка или флажок) | 3 |
E: not (s) | элемент E, который не соответствует простому селектору s | 3 |
E ~ F <512 элемент>F, который предшествует элемент E | 3 |
Блок объявления состоит из списка объявлений в фигурных скобках. Каждое объявление состоит из, двоеточия (:
) и значения. Если в блоке несколько объявлений, необходимо вставить точку с запятой (;
) для разделения каждого объявления.
Свойства указаны в стандарте CSS. У каждого свойства есть набор эффектов. Некоторые свойства могут влиять на любой тип элемента, а другие применяются только к определенным группам элементов.
Значения могут быть ключевыми словами, например «центр» или «наследование», или числовыми значениями, например 200 пикселей
(200 пикселей), 50vw
(50 процентов ширины области просмотра) или 80% (80 процентов ширины родительского элемента). Значения цвета могут быть указаны ключевыми словами (например, "красный
"), шестнадцатеричными значениями (например, # FF0000
, также сокращенно # F00
), значениями RGB на Масштаб от 0 до 255 (например,
), значения RGBA, которые определяют как цвет, так и альфа-прозрачность (например, rgb (255, 0, 0)
rgba (255, 0, 0, 0,8)
), или значения HSL или HSLA (например, hsl (000, 100%, 50%)
, hsla (000, 100 %, 50%, 80%)
).
Ненулевые числовые значения, представляющие линейные меры, входящую единицу длины, которая является буквенным кодом, либо сокращ, как в 200px
или 50vw
; или знак процента, как в 80%
. Некоторая единица - cm
(сантиметр ); in
(дюйм ); mm
(миллиметр ); pc
(pica ); и pt
(point ) - абсолютными, что означает, что отображаемый размер не зависит от структуры страницы; прочие - em
(em ); ex
(ex ) и px
(пиксель ) - относительны, что означает, что такие факторы, как размер шрифта родительского элемента, могут повлиять на визуализированное измерение. Эти восемь особенностей были особенностью CSS 1 и сохранялись во всех редакциях. Предлагаемый модуль значений и единиц CSS уровня 3, если он будет принят в качестве рекомендации W3C, предоставит еще семь единиц длины: ch
; Q
; rem
; vh
; vmax
; vmin
; и vw
.
До появления CSS почти все атрибуты представления документов HTML содержались в разметке HTML. Все цвета шрифтов, стили фона, выравнивание элементов, границы и размеры должны быть явно стимулы, часто многократно, в HTML. CSS позволяет авторам перемещать большую часть этой информации в другой файл, таблицу стилей, что упрощает HTML.
Например, заголовки (h1
элементы), подзаголовки (div class="ht"
), подзаголовки (h3
) и т. Д.., структурно ориентированная с помощью HTML. В печати и на экране выбор шрифта, размера, цвета и выделения для этих элементов является презентационным.
До появления CSS авторам документов, которые хотели присвоить такие типографические характеристики, скажем, всем заголовкам div class="ht"
, приходилось повторять презентационную разметку HTML для каждого вхождения этого типа заголовка.. Это сделало документы более сложными, крупными, подверженными ошибкам и сложными в обслуживании. CSS позволяет отделить представление от структуры. CSS может определять цвет, шрифт, выравнивание текста, размер, границы, интервал, макет и многие другие типографские характеристики независимо для экранных и печатных видов. CSS также определяет невизуальные стили, такие как скорость чтения и акцент для чтения на слух. W3C теперь не рекомендует использовать всю презентационную разметку HTML.
Например, в HTML до CSS, заголовок элемента, определенным красным текстом, будет записан как:
CSS - CSS
Используя CSS, тот же элемент может быть закодирован с использованием стиля вместо атрибутов представления HTML :
CSS - CSS
Преимущества этого могут быть не сразу стиля очевидны, но сила CSS становится более очевидным, когда свойства помещаются во внутренний элемент стиля или, что еще лучше, внешний файл CSS. Например, предположим, что документ содержит элемент стиля:
Все элементы h1
в документе автоматически становятся красными без необходимости в явном коде. Если позже автор захотел сделать элементы h1
синими, это можно было бы сделать, изменив стиль элемента на:
вместо того, чтобы кропотливо просмотреть документ и проверить цвет для каждого отдельного элемента h1
.
Стили также могут быть помещены во внешний файл CSS. внешний файл CSS.
Информация CSS может быть предоставлена из различных источников. Этими источниками могут быть веб-браузер, пользователь и автор. Информация от автора может быть классифицирована по встроенным, типам мультимедиа, важности, специфичности селектора, порядку правил, наследованию и определению свойств. Информация о стиле CSS может быть в отдельном документе или встроена в документ HTML. Можно импортировать несколько таблиц стилей. В зависимости от используемого устройства вывода разные стили; например, экранная версия может сильно отличаться от печатной, поэтому авторы могут адаптировать презентацию для каждого носителя.
Таблица стилей с наивысшим приоритетом управляет отображением содержимого. Объявления не устанавливаются в новом порядке с более низким приоритетом, например, в стиле пользователя агента. Процесс называется каскадным.
Одна из целей CSS - предоставить пользователям больший контроль над представлением. Тот, кому трудно читать красные курсивные заголовки, может применить другую таблицу стилей. Пользователь может выбирать из различных таблиц стилей, предоставленных дизайнерами, или может удалить все добавленные стили и просматривать сайт, используя стиль по умолчанию, или заменить только красный курсивный стиль заголовка без изменений других атрибутов.
Priority | Тип источника CSS | Описание | |
---|---|---|---|
1 | Importance | «! Важно "аннотация перезаписывает предыдущие типы приоритета | |
2 | Inline | Стиль, примененный к элементу HTML с помощью атрибута HTML" style " | |
3 | Тип носителя | Определение свойств применяемого ко всем типам носителя, если не определен CSS для конкретного селектора | |
4 | Определен носитель | Большинство браузеров имеют функции специальных возможностей: определенные пользовательские селекторы CSS | |
5 | p) перезаписывает общее определение | ||
6 | Порядок правил | Последнее объявление правила имеет более высокий приоритет | |
7 | Родительское наследование | Если свойство не указано, оно наследуется от родительского элемента | |
8 | Определение свойств Методы CSS в документе HTML | Правило CSS или встроенный стиль CSS перезаписывают значение по умолчанию | Самый низкий приоритет: значение по умолчанию для определен. W3C начальная валюта Технические характеристики ue |
Специфика относится к относительным весам различных правил. Он определяет, какие стили применяются к элементу. В зависимости от спецификации простой селектор (например, H1) имеет специфичность 1, селекторы классов имеют специфичность 1,0, а селекторы имеют специфичность 1,0,0. Характеристики специфичности не переносятся, как в десятичной системе, запятые используются для разделения цифр (правило CSS, имеющее 11 элементов и 11 классов, будет иметь специфичность 11,11, а не 121).
Таким образом, следующие селекторы обеспечивают высокую специфичность:
Селекторы | Специфичность |
---|---|
H1 {color: white;} | 0, 0, 0, 1 |
P EM {color: green;} | 0, 0, 0, 2 |
.grape {color: red;} | 0, 0, 1, 0 |
P.bright {color: blue ;} | 0, 0, 1, 1 |
P.bright EM.dark {color: yellow;} | 0, 0, 2, 2 |
# id218 {color: brown;} | 0, 1, 0, 0 |
style = "" | 1, 0, 0, 0 |
Рассмотрим этот фрагмент HTML:
Для демонстрации специфичности
В примере выше объявления в атрибуте стиль
переопределяет объявление в элементе , потому что оно имеет более высокую специфичность, и поэтому абзац выглядит зеленым.
Наследование - это ключевая особенность CSS; он полагается на отношения «предок-потомок». Наследование - это механизм, с помощью которого применяются свойства не только к указанному элементу, но и к его потомкам. Наследование основывается на дереве документа, которое представляет собой иерархию элементов 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, но с модификациями». С помощью CSS можно стилизовать элемент с «классом A, но с изменениями». Однако невозможно определить подобный CSS-класс B, который затем можно было бы использовать для стилизации нескольких элементов без повторения изменений.
Дана следующая таблица стилей:
h1 {color: pink; }
Предположим, что есть элемент h1 с подчеркивающим элементом (em) внутри:
CSS - CSS
Если элемент em не назначен цвет, выделенное слово " illustrate "наследует цвет родительского элемента h1. Таблица стилей h1 имеет розовый цвет, следовательно, элемент em также розовый.
Пробелы между свойствами и селекторами игнорируются. Этот фрагмент кода:
body {overflow: hidden; background: # 000000; background-image: url (images / bg.gif); фон-повтор: без повторения; background-position: left top;}
функционально эквивалентен этому:
body {overflow: hidden; цвет фона: # 000000; фоновое изображение: url (images / bg.gif); фон-повтор: без повторения; положение фона: слева вверху; }
Одним из распространенных способовформатирования CSS для удобства чтения отступает для каждого свойства и предоставление отдельной строки. В дополнение к форматированию CSS для чтения, сокращенные свойства ссылки для более быстрого написания кода, который также быстрее обрабатывается при визуализации:
body {overflow: hidden; фон: # 000 url (images / bg.gif) без повтора слева вверху; }
CSS 2.1 определяет три схемы позиционирования:
Существует четыре значения свойства Позиция
. Если элемент расположен каким-либо образом, кроме статический
, тогда дополнительные свойства верх
, низ
, левый
и правый
используются для указаний и позиций.
Свойство float
может иметь одно из трех значений. Абсолютно позиционированные или фиксированные элементы не могут быть перемещены. Другие элементы обычно обтекают плавающие элементы, если это не запрещено их своим очистить
.
clear: left
), справа (ясно: справа
) или с обеих сторон (ясно: обе
).CSS был впервые предложен Хоконом Виум Ли 10 октября 1994 года. В то время Ли работал с Тимом Бернерсом-Ли в ЦЕРН. Примерно в то же время было предложено несколько других языков таблиц стилей для Интернета, и обсуждения в общедоступных списках рассылки и внутри Консорциума World Wide Web привело к тому, что в 1996 году была выпущена первая Рекомендация W3C CSS (CSS1). В частности, большое влияние оказало предложение Берта Боса ; соавтором CSS1 и считается соавтором CSS.
Таблицы стилей существуют в одной форме или с самого начала Standard Generalized Markup Language (SGML ) в 1980-х годах, а CSS бы л разработан для предоставления таблиц стилей для Интернета. Одно из требований к языку веб-таблиц стилей заключалось в том, чтобы таблицы источников поступали из разных источников в Интернете. Следовательно, усилием таблиц стилей, такие как DSSSL и FOSI, не подходят. CSS, с другой стороны, позволяет влиять на стиль документа с помощью нескольких таблиц стилей посредством «каскадных» стилей.
По мере роста HTML он стал охватывать более широкий спектр стилистических возможностей для удовлетворения требований веб-разработчики. Эта эволюция дала дизайнеру больше контроля над видом сайта за счет более сложного HTML. Различия в реализации веб-сайтов, таких как ViolaWWW и WorldWideWeb, затрудняли единообразный внешний вид сайта, и пользователи имели меньше контроля над отображением веб-контента. Браузер / редактор, предлагаем Тимом Бернерс-Ли, имел таблицу стилей, жестко закодированные в программе. Поэтому таблицы стилей не могли быть связаны с документами в сети. Роберт Кайо, также из ЦЕРН, хотел отделить структуру от презентации, чтобы разные таблицы стилей могли описывать разные представления для печати, на основе экрана презентаций и редакторов.
Улучшение возможностей веб-презентаций было предложено темой, интересной для многих в веб-сообществе, и девять различных языков таблиц стилей были предложены в списке рассылки www-style. Из этих девяти предложений два особенно повлияли на то, что стало CSS: каскадные таблицы стилей HTML и предложения таблиц стилей на основе потоков (SSP). Два сайта служили тестовыми площадками для первоначальных предложений; Ли работал над внедрением CSS в браузере Дэйва Рэггетта Arena. Берт Бос реализовал собственное предложение SSP в браузере Арго. После этого Ли и Бос работали вместе над разработкой стандарта CSS (буква «H» была удалена из названия, потому что эти таблицы стилей также можно было применять к другим языкам разметки помимо HTML).
Предложение Ли было представлено на конференции. "" конференция (позже названная WWW2) в Чикаго, штат Иллинойс, в 1994 году, и снова с Бертом Босом в 1995 году. Примерно в это время уже создавалась W3C, которая проявляла интерес к развитию CSS. С этой целью он организовал семинар под председательством Стивена Пембертона. Это привело к тому, что W3C добавил работу над CSS к результатам работы редакционной комиссии HTML (ERB). Ли и Бос были основным техническим аспектом проекта, с дополнительными членами, в том числе Томасом Рирдоном из Microsoft. В августе 1996 года Netscape Communication Corporation представила альтернативный язык таблиц стилей под названием Таблицы стилей JavaScript (JSSS). Спецификация так и не была закончена и устарела. К концу 1996 года CSS был готов, и в декабре была опубликована официальная рекомендация CSS уровня 1.
Разработка HTML, CSS и DOM велась в одной группе - Редакционной комиссии HTML (ERB). В начале 1997 года ERB был разделен на три рабочие группы: Рабочая группа HTML, защищаемая Дэном Коннолли из W3C; Рабочая группа DOM под председательством Лорен Вуд из SoftQuad ; и рабочая группа CSS под председательством Криса Лилли из W3C.
Рабочая группа CSS начала проблем, которые не были решены с помощью CSS уровня 1, в результате чего 4 ноября 1997 года был создан CSS уровня 2. 12 мая 1998 года он был опубликован как Рекомендация W3C. Уровень 3 CSS, который был запущен в 1998 году, все еще находится в стадии разработки по состоянию на 2014 год.
В 2005 году рабочие группы CSS решили ужесточить требования к стандартам. Это означало, что уже опубликованные стандарты, такие как CSS 2.1, CSS 3 Selectors и CSS 3 Text, были перенесены с уровня кандидата Рекомендации на уровень рабочего проекта.
Спецификация CSS 1 была завершена в 1996 году. В том же году был выпущен Microsoft Internet Explorer 3 с некоторой известной поддержкой CSS. В IE 4 и Netscape 4.x была дополнительная поддержка, но она обычно не содержала множества ошибок, которые мешали полноценному применению CSS. Прошло более трех лет, прежде чем какой-либо веб-браузер достиг почти полной реализации. Internet Explorer 5.0 для Macintosh, поставленный в марте 2000 г., был первым браузером, который получил полную (лучше 99%) поддержку CSS 1, превзойдя Opera, который был лидером с момента введения поддержки CSS пятнадцатью месяцами ранее. Быстрые последовательные и другие браузеры, и многие из них реализовали CSS 2.
Однако, даже когда более поздние веб-браузеры «5» начали предлагать довольно полную версию CSS. и чреваты несоответствиями, ошибками и прочими причудами. Microsoft Internet Explorer 5.x для Windows, в отличие от совершенно другого IE для Macintosh, имел место некорректную реализацию 'блочной модели CSS ', поскольку по сравнению со стандартами CSS. Такие несоответствия и различия в поддержке функций затрудняли создание вида предоставления единообразного внешнего интерфейса в браузерах и платформых без использования обходных путей, называемых хаками и фильтрами CSS. Ошибки блочной модели IE / Windows были настолько серьезными, что когда был выпущен Internet Explorer 6, Microsoft представила обратно совместимый режим интерпретации CSS ('quirks mode ') наряду с альтернативой., поправил "стандартный режим". Другие браузеры сторонних производителей также предоставляют такую возможность переключения режимов. Поэтому у авторов файлов 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 г. и вернулся в статус кандидата в рекомендации только 19 июля 2007 г.
В дополнение к Из-за этих проблем расширение файлов.cssиспользовалось программным продуктом для преобразования файлов PowerPoint в файлы компактного слайд-шоу, поэтому некоторые веб-серверы обслуживали все .css
as MIME-тип application / x-pointplus
, а не text / css
.
CSS имеет уровни и профили. Каждый CSS строится на последнем, обычно добавляя новые функции и обычно обозначаемый как CSS 1, CSS 2, CSS 3 и CSS 4. Профили обычно представляют собой подмножество одного или нескольких уровней CSS, созданных для конкретного устройства или пользовательского интерфейса.. На данный момент существуют профили для мобильных устройств, принтеров и телевизоров. Профили не следует путать с типами мультимедиа, которые были добавлены в CSS 2.
Первой спецификацией CSS, которая стала официальной рекомендацией W3C, является уровень CSS 1, опубликованный 17 декабря. 1996. Хокон Виум Ли и Берт Бос считаются первоначальными разработчиками. Среди его возможностей - поддержка свойств
W3C больше не поддерживает Рекомендацию CSS 1.
Спецификация CSS уровня 2 была разработана W3C и опубликована в качестве рекомендации в Май 1998. Надмножество CSS 1, CSS 2 включает ряд новых возможностей, таких как абсолютное, относительное и фиксированное позиционирование элементов и z-index, концепция типов мультимедиа, поддержка звуковых таблиц стилей ( которые позже были заменены речевыми модулями CSS 3) и двунаправленным текстом, а также новыми свойствами шрифта, такими как тени.
W3C больше не поддерживает рекомендацию CSS 2.
CSS уровня 2, версия 1, часто называемая «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 года. После рассмотрения Консультативным комитетом W3C она была наконец опубликована в качестве Рекомендации W3C 7 июня 2011 года.
CSS 2.1 планировался как первая и последняя редакция уровня 2, но низкая Приоритетная работа над CSS 2.2 началась в 2015 году.
В отличие от CSS 2, который представляет собой большую единую спецификацию, определяющую различные функции, CSS 3 разделен на несколько отдельных документов, называемых «модулями». Каждый модуль использует новые возможности или расширяет функции, в CSS 2, с сохранением обратной совместимости. Работа над уровнем CSS 3 началась примерно во время публикации исходной рекомендации CSS 2. Самые ранние черновики CSS 3 были опубликованы в июне 1999 года.
Из-за модульности разные модули имеют разную стабильность и статусы.
Некоторые модули Рекомендуют кандидата (CR) статус и считаются умеренно стабильными. На этапе реализации CR рекомендуется отбрасывать префиксы поставщиков.
Модуль | Название спецификации | Статус | Дата |
---|---|---|---|
css3-background | CSS Backgrounds and Borders Module Level 3 | Кандидат Рек. | окт 2017 |
css3-box | Базовая блочная модель CSS | Рабочий проект | июль 2018 |
css-cascade-3 | CSS-каскадирование и наследование уровня 3 | кандидат Рек. | май 2016 г. |
css3-color | CSS Color Module Level 3 | Рекомендация | июнь 2018 г. |
css3-content | Модуль содержимого для создания и замены CSS3 | Рабочий проект | июнь 2016 г. |
css-fonts-3 | CSS Модуль шрифтов, уровень 3 | Рекомендация | Сентябрь 2018 г. |
css3-gcpm | Содержимое, сгенерированное CSS для страничного медиа-модуля | Рабочий проект | Май 2014 г. |
css3- layout | Модуль макета шаблона CSS | Note | март 2015 г. |
css3-mediaqueries | Media Queries | Рекомендация | июнь 2012 г. |
mediaqueries-4 | Медиа Ку эриес Уровень 4 | Кандидат Rec. | Сентябрь 2017 г. |
css3-multicol | Модуль макета с изолированными столбцами Уровень 1 | Рабочий проект | Май 2018 г. |
css3 -page | CSS Страничный медиа-модуль уровня 3 | Рабочий проект | март 2013 г. |
selectors-3 | Selectors Level 3 | Рекомендация | ноябрь 2018 г. |
селекторы-4 | Селекторы уровня 4 | Рабочий проект | февраль 2018 г. |
css3-ui | Модуль базового пользовательского интерфейса CSS, уровень 3 (CSS3 UI) | Рекомендация | июнь 2018 |
Не существует единой интегрированной спецификации CSS4, потому что спецификация была разделена на множество модулей, уровни табуляции.
Модули, которые основаны на вещах из CSS уровня 2, начались на уровне 3. Некоторые из них уже достигли уровня 4 или уже приближаются к уровню 5. Другие модули, которые определяют совершенно новые функции, такие как Flexbox, были как показатели Уровень 1, из них некоторые приближа к Уровню 2.
Рабочая группа CSS иногда публикует «Снимки», совокупность целых модулей и частей других проектов, которые достаточно стабильны, будут. реализованы На данный момент пять таких документов с «передовой практикой» опубликованы в виде заметок в 2007, 2010, 2015, 2017 и 2018 годах.
эти снимки спецификаций предназначены в первую очередь для разработчиков, спрос на них растет. как аналогичный справочный документ с версией, нацеленный на авторов, который будет представлять собой совместимых реализаций, как тем временем задокументировано такими сайтами, как я могу использовать… и Сеть разработчиков Mozilla. Группа сообщества W3C создана в начале 2020 года для обсуждения и определения такого ресурса. Фактический вид управления версией является также предметом обсуждения, а это означает, что этот новый документ может не называться «CSS4».
Каждый веб-браузер использует механизм макета для отображения веб-страниц, и поддержка функциональности CSS между ними не согласована. Оптимально, браузеры не анализируют CSS, было разработано несколько методов кодирования, предназначенных для конкретных браузеров с помощью обходных путей (обычно предпочитаемых хаки CSS или фильтров CSS). Принятие новых функций в CSS может помешать отсутствие поддержки в основных браузерах. Например, Internet Explorer не спешил использовать поддержку многих функций CSS 3, что замедляло внедрение этих функций и нанесло ущерб репутации среди разработчиков. Чтобы единообразие взаимодействия с тестерами, веб-разработчики используют свои тесты в разных системах, браузерах и версиях браузеров, что обеспечивает и сложность разработки. Такие инструменты, как BrowserStack, были созданы для упрощения обслуживания этих сред.
В дополнение к этому инструменту тестирования многие сайты списки поддержки браузеров, CSS, включая CanIUse и Mozilla Developer Network. Кроме того, CSS 3 предоставляет запросы функций, которые директиву @supports
, которые позволяют разработчикам настраивать таргетинг в браузерах с поддержкой определенных функций в их CSS. CSS, который не поддерживается старыми браузерами, также иногда можно исправить с помощью JavaScript polyfills, которые предоставляют собой фрагменты кода JavaScript, разработанные для обеспечения согласованного поведения браузеров. Эти обходные пути - также необходимость поддержки резервных функций - могут усложнить проекты разработки, и, следовательно, компании часто определяют список версий браузеров, которые они будут и не будут поддерживать.
веб-сайты веб-сайты принимают новые стандарты кода, несовместимые со старыми браузерами, эти браузеры могут быть отключены от доступа многим ресурсам в Интернете (иногда намеренно). Многие из самых популярных сайтов в Интернете не только визуально плохо работают в старых браузерах из-за плохой поддержки CSS, но и вообще не работают, в степени из-за развития JavaScript и других веб-технологий.
Некоторые отмеченные ограничения текущих возможностей CSS включают:
: hover
», является динамическим (эквивалент JavaScript «onmouseover») и имеет потенциал для неправильного использования (например, реализация всплывающих окон с приближением курса), но CSS не имеет возможности для клиента, чтобы отключить его (нет свойства типа «отключить») или ограничить его эффекты (значения типа «без изменения» для каждого свойства).: первая буква
, невозможно настроить таргетинг на уровни диапазона текста без использования элементов-заполнителей.Кроме того, в предыдущих версиях стандарта CSS присутствовало еще несколько проблем, но они были устранены:
margin-left: 10% - 3em + 4px;
). Это было бы полезно во множестве случаев, например, при вычислении размера столбцов с учетом ограничения суммы всех столбцов. Internet Explorer версии 5–7 поддерживает собственное выражение () с аналогичной функциональностью. Этот проприетарный оператор выражение () больше не поддерживается с Internet Explorer 8, за режим совместимости. Это решение было принято из соображений «соответствия стандартам, производительности и безопасности». Тем не менее, рекомендация кандидата с менее известными () для устранения ограничения этой опубликованной рабочей группой CSS и с тех пор поддерживается во всех современных браузерах.column-count
), макеты с разделенными столбцами могут быть сложными для реализации в CSS 2.1. В CSS 2.1 процесс часто выполняется с использованием плавающих элементов, которые часто по-разному в разных браузерах, разных формах экрана компьютеров и разных соотношениях экрана, стандартных мониторах. Все современные браузеры в той или иной форме формы эту функцию CSS 3.класс
, тип или отношение к другим. Это намного эффективнее, чем повторение информации о стиле в строке для каждого вхождения элемента. Внешняя таблица стилей обычно хранится в кэше и поэтому может быть на нескольких страницах без загрузки, что обычно сокращает передачу данных по сети.Фреймворки CSS - это подготовленные библиотеки, которые предназначены для упрощения, подробнее соответствие стандартам оформление веб-страниц с использованием языка каскадных таблиц стилей. CSS-фреймворки включают Blueprint, Bootstrap, Cascade Framework, Foundation и Materialise. Подобно библиотекам языков программирования и сценариев, CSS-фреймворки обычно включаются в виде внешних таблиц.css, на которые есть ссылки в HTML . Некоторые из них используют их в предварительном режиме, или для обучения, и используют «ручное создание» CSS, который подходит для каждого из них, без дополнительных затрат на проектирование., обслуживать ание и загрузку из-за неиспользуемых функций в стиле сайта.
По мере увеличения размера ресурсов CSS, используемого в проекте командой разработчиков, часто требуется выбрать общую методологию проектирования, чтобы поддерживать их организованность. Целями являются простота разработки, простота совместной работы во время разработки и развертывания таблиц стилей в браузере. Популярные методологии включают OOCSS (объектно-ориентированный CSS), ACSS (атомарный CSS), oCSS (органическая каскадная таблица стилей), SMACSS (масштабируемая и модульная архитектура для CSS) и BEM (блок, элемент, модификатор).