Значения стилевых свойств. Что такое CSS, для чего нужны стили CSS

Мы выпустили новую книгу «Контент-маркетинг в социальных сетях: Как засесть в голову подписчиков и влюбить их в свой бренд».

Подписаться

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

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

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

Принцип работы CSS

Принцип работы основывается на том, что CSS находит определенный элемент HTML (заголовок) и определяет для него конкретное свойство (цвет), чтобы присвоить ему значение (красный). Прописывается это так:

CSS применяется для выполнения стилистических решений, а также для компоновки документов типа HTML: задачи высоты, колонок, размещения элементов и так далее.

Как и где можно написать CSS

  • CSS может быть прописан как атрибут непосредственно в HTML.

  • Можно применять тег

    Пример текста

    Если в десятичной дроби целая часть равна нулю, то её разрешается не писать. Запись .7 и 0.7 равнозначна.

    Проценты

    Процентная запись обычно применяется в тех случаях, когда надо изменить значение относительно родительского элемента или когда размеры зависят от внешних условий. Так, ширина таблицы 100% означает, что она будет подстраиваться под размеры окна браузера и меняться вместе с шириной окна (пример 6.3).

    Пример 6.3. Процентная запись

    HTML5 CSS 2.1 IE Cr Op Sa Fx

    Ширина в процентах

    Содержимое таблицы

    Проценты не обязательно должны быть целым числом, допускается использовать десятичные дроби, вроде значения 56.8%.

    Размеры

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

    Относительные единицы

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

    Единица em это изменяемое значение, которое зависит от размера шрифта текущего элемента (размер устанавливается через стилевое свойство font-size ). В каждом браузере заложен размер текста, применяемый в том случае, когда этот размер явно не задан. Поэтому изначально 1em равен размеру шрифта, заданного в браузере по умолчанию или размеру шрифта родительского элемента. Процентная запись идентична em , в том смысле, что значения 1em и 100% равны.

    Единица ex определяется как высота символа «x» в нижнем регистре. На ex распространяются те же правила, что и для em , а именно, он привязан к размеру шрифта, заданного в браузере по умолчанию, или к размеру шрифта родительского элемента.

    Пиксел это элементарная точка, отображаемая монитором или другим подобным устройством, например, смартфоном. Размер пиксела зависит от разрешения устройства и его технических характеристик. В примере 6.4 показано применение пикселов и em для задания размера шрифта.

    Пример 6.4. Использование относительных единиц

    HTML5 CSS 2.1 IE Cr Op Sa Fx

    Относительные единицы

    Заголовок размером 30 пикселов

    Размер текста 1.5 em

    Результат данного примера показан ниже (рис. 6.1).

    Рис. 6.1. Размер текста при различных единицах

    Абсолютные единицы

    Абсолютные единицы применяются реже, чем относительные и обычно при работе с текстом. В табл. 6.2 перечислены основные абсолютные единицы.

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

    Пример 6.5. Использование абсолютных единиц

    HTML5 CSS 2.1 IE Cr Op Sa Fx

    Абсолютные единицы

    Заголовок размером 24 пункта

    Сдвиг текста вправо на 30 миллиметров

    Результат использования абсолютных единиц измерения показан ниже (рис. 6.2).

    Рис. 6.2. Размер текста при различных единицах

    При установке размеров обязательно указывайте единицы измерения, например width : 30px . В противном случае браузер не сможет показать желаемый результат, поскольку не понимает, какой размер вам требуется. Единицы не добавляются только при нулевом значении (margin : 0 ).

    Цвет

    Цвет в стилях можно задавать тремя способами: по шестнадцатеричному значению, по названию и в формате RGB.

    По шестнадцатеричному значению

    Для задания цветов используются числа в шестнадцатеричном коде. Шестнадцатеричная система, в отличие от десятичной системы, базируется, как следует из ее названия, на числе 16. Цифры будут следующие: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F. Цифры от 10 до 15 заменены латинскими буквами. Числа больше 15 в шестнадцатеричной системе образуются объединением двух чисел в одно. Например, числу 255 в десятичной системе соответствует число FF в шестнадцатеричной системе. Чтобы не возникало путаницы в определении системы счисления, перед шестнадцатеричным числом ставят символ решетки #, например #666999. Каждый из трех цветов - красный, зеленый и синий - может принимать значения от 00 до FF. Таким образом, обозначение цвета разбивается на три составляющие #rrggbb, где первые два символа отмечают красную компоненту цвета, два средних - зелёную, а два последних - синюю. Допускается использовать сокращенную форму вида #rgb, где каждый символ следует удваивать (#rrggbb). К примеру, запись #fe0 расценивается как #ffee00.

    По названию

    Браузеры поддерживают некоторые цвета по их названию. В табл. 6.3 приведены названия, шестнадцатеричный код и описание.

    Табл. 6.3. Названия цветов
    Имя Цвет Код Описание
    white #ffffff или #fff Белый
    silver #c0c0c0 Серый
    gray #808080 Тёмно-серый
    black #000000 или #000 Чёрный
    maroon #800000 Тёмно-красный
    red #ff0000 или #f00 Красный
    orange #ffa500 Оранжевый
    yellow #ffff00 или #ff0 Жёлтый
    olive #808000 Оливковый
    lime #00ff00 или #0f0 Светло-зелёный
    green #008000 Зелёный
    aqua #00ffff или #0ff Голубой
    blue #0000ff или #00f Синий
    navy #000080 Тёмно-синий
    teal #008080 Сине-зелёный
    fuchsia #ff00ff или #f0f Розовый
    purple #800080 Фиолетовый

    С помощью RGB

    Можно определить цвет, используя значения красной, зелёной и синей составляющей в десятичном исчислении. Значение каждого из трех цветов может принимать значения от 0 до 255. Также можно задавать цвет в процентном отношении. Вначале указывается ключевое слово rgb , а затем в скобках, через запятую указываются компоненты цвета, например rgb(255, 0, 0) или rgb(100%, 20%, 20%).

    В примере 6.6 представлены различные способы задания цветов элементов веб-страниц.

    Пример 6.6. Представление цвета

    HTML5 CSS 2.1 IE Cr Op Sa Fx

    Цвета

    Lorem ipsum dolor sit amet

    Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat.

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

    Адреса

    Адреса (URI , Uniform Resource Identifiers, унифицированный идентификатор ресурсов) применяются для указания пути к файлу, например, для установки фоновой картинки на странице. Для этого применяется ключевое слово url() , внутри скобок пишется относительный или абсолютный адрес файла. При этом адрес можно задавать в необязательных одинарных или двойных кавычках (пример 6.7).

    Пример 6.7. Адрес графического файла

    HTML5 CSS 2.1 IE Cr Op Sa Fx

    Добавление фона

    Внимание, запрашиваемая страница не найдена!

    В данном примере в селекторе body используется абсолютный адрес к графическому файлу, а в селекторе div - относительный.

    Ключевые слова

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

    Правильно: P { text-align: right; }
    Неверно: P { text-align: "right"; }

    Вопросы для проверки

    1. В какой строке содержится ошибка?

    1. font-size: 20px
    2. font-size: 0
    3. font-size: 1,5em
    4. font-size: 5mm
    5. font-size: 300ex

    2. Какое выражение написано корректно?

    1. color: #fco
    2. width: "auto"
    3. font-size: blue
    4. bakground: red
    5. border: none

    3. Какой размер в пунктах будет у текста

    Пример текста

    , если на странице задан следующий стиль?

    BODY { font-size: 24pt; }
    P { font-size: 50%; }
    SPAN { font-size: 1.5em; }

    4. Ане хочется установить сиреневый цвет фона веб-страницы. Какое значение свойства background подойдёт лучше всего?

    1. #cbd1e8
    2. rgb(121, 232, 47)
    3. #b6b7be
    4. rgb(205%, 85%, 53%)

    5. Какая ошибка содержится в следующем стиле?

    img { float: left; border-width: 3; display: block }

    1. Не хватает точки с запятой в конце записи.
    2. Не указаны единицы измерения свойства border-width.
    3. Значения left и block написаны без кавычек.
    4. Свойства border-width не существует.
    5. Значение block свойства display не допускается применять к изображениям.

    Ответы

    1. font-size: 1,5em

    5. Не указаны единицы измерения свойства border-width.

    CSS – это формальный язык, служащий для описания оформления внешнего вида документа, созданного с использованием языка разметки (HTML, XHTML, XML). Название происходит от английского Cascading Style Sheets, что означает «каскадные таблицы стилей».

    Зачем используется CSS

    Назначение CSS – отделять то, что задает внешний вид страницы, от ее содержания. Если документ создан только с использованием HTML, то в нем определяется не только каждый элемент, но и способ его отображения (цвет, шрифт, положение блока и т. д.). Если же подключены каскадные таблицы стилей, то HTML описывает только очередность объектов. А за все их свойства отвечает CSS. В HTML достаточно прописывать класс, не перечисляя все стили каждый раз.

    Такая технология:

    • обеспечивает относительно простую и быструю разработку, потому что однажды созданное оформление можно применять ко многим страницам;
    • повышает гибкость и удобство редактирования – достаточно внести правку в CSS, чтобы оформление изменилось везде;
    • делает код более простым, снижая повторяемость элементов. Его проще читать программистам и поисковым ботам;
    • ускоряет время загрузки, потому что CSS может кэшироваться при первом открытии, а в последующих считываются только структура и данные;
    • увеличивает количество визуальных решений для представления содержимого;
    • обеспечивает возможность легко применять к одному документу разные стили (например, создавать адаптированную версию для мобильных устройств или специальные стили для слабовидящих).

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

    Развитие CSS

    Необходимость разработки CSS была признана консорциумом W3C в 1990-х годах. В 1996 году был принят стандарт CSS1, позволяющий изменять параметры шрифта, цвет, атрибуты текста, выравнивания и отступы. В 1998 году состоялся выход CSS2, добавивший возможности использования блочной верстки, звуковых таблиц, генерируемого содержания, указателей, страничных носителей. Версия CSS3 заметно увеличила возможности стилей: стало доступным создание анимированных элементов без использования JavaScript, появилась поддержка сглаживания, теней, градиентов и т. д. Спецификация была разделена на модули, каждый из которых стал развиваться обособленно. С 2011 года ведется разработка модулей CSS4. Возможности пока описаны в черновых вариантах.

    Структура языка

    CSS можно охарактеризовать простыми словами как набор правил, описывающих, как должен выглядеть элемент.

    Правило состоит из селектора и блока объявлений.

    Селекторы

    Селектор сообщает, к какому элементу будут применены описываемые в CSS свойства стиля. В качестве селектора может выступать любой тег, которому задается форматирование (размер, цвет и т. д.). Если для тега нужно задать разные стили или применить один для отличных элементов, используются классы и запись вида «Тег.Класс {свойство: значение;}». Имя класса задается латиницей, может содержать подчеркивание или дефис. Если не указывать тег, а начинать запись с «.Класс», то можно использовать правило для любого тега. Если перечислять несколько классов для одного тега, к нему применятся все описанные стили. Идентификатор задает уникальное имя элемента для изменения стиля или обращения с помощью скрипта. Запись «#Идентификатор {свойство: значение;}». Название идентификатора состоит из букв латинского алфавита, допустимо использовать дефис и подчеркивание. Чтобы применить идентификатор к конкретному тегу, указывается его имя, потом без пробела и через знак решетки название идентификатора.

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

    Блок объявлений состоит из пар «свойство: значение» (запись всегда черед двоеточие), размещенных в фигурных скобках. Записи заканчиваются точкой с запятой. CSS нечувствителен к табуляции, пробелам, регистру. Выбор способа записи (столбиком с отступами или просто в строчку) остается на усмотрение разработчика. Если для одного селектора прописаны разные значения для одного свойства, то приоритет отдается нижней записи.

    Подключение CSS

    CSS можно связать с HTML несколькими способами:

    • внутри тега с помощью атрибута style. При этом нет нужды указывать селектор;
    • добавить тег