CSS - Cascading Style SheetsСергей Витальевич Щербаков, webmaster@id.agava.ru, wtReu@inbox.ru Часть I. Что есть CSSНемного о CSS Так что это такое - СSS? Cascading Style Sheets (Таблицы Каскадных Стилей) - это язык, содержащий набор свойств для описания внешнего вида любых HTML документов. С его помощью дизайнер имеет полный контроль над стилем и расположением каждого элемента веб страницы, что проще и гораздо функциональнее использования обычного набора HTML тегов. Приведу пример: Вам нужно создать жирный красный подчеркнутый текст. ПРИМЕР HTML: <font color="red"><strong><u> Какой-то текст </u></strong></font> А если подобный стиль нужно использовать несколько раз? Хорошо если раз 5, а если 10-20? Вот тут нам и поможет СSS. Существует три вида таблиц стилей: Внутренние таблицы стилей, Глобальные таблицы стилей и Связанные таблицы стилей. Внутренние таблицы стилей (Inline Style Sheets) при помощи специального атрибута помещаются прямо в HTML теги. Глобальные (Global Style Sheets) определяют стиль элементов во всем документе. Связанные (Linked Style Sheets) могут быть использованы для нескольких документов сразу и хранятся во внешнем файле. Подробнее обо всем этом написано ниже. Структура и правила Селекторы (Selectors): Синтаксисис: Любой элемент HTML - это возможный CSS селектор. Свойства селектора определяют стиль элемента, для которого он определен. ПРИМЕР: H1 {color:red; size:20pt;} Все элементы H1 в документе будут красного цвета, размером в 20 точек (pt, point). Классовые селекторы (Class Selectors): Синтаксис: CLASS - атрибут элемента в HTML, определяющий его класс. В CSS можно описать собственные стили для различных классов одних и тех же элементов. ПРИМЕР: H1.blue {color:blue; size:20pt;} Все элементы H1 с атрибутом CLASS="blue" станут синими. Классы могут так же быть описаны без явного привязывания их к определенным элементам. Синтаксис: ПРИМЕР: .green {color:green;} В данном случае все элементы с атрибутом CLASS="green" станут зелеными. ID селекторы (ID Selectors): Cинтакс: ID - индивидуально именованный стиль. C его помощью можно создавать стилистические исключения cреди элементов одного класса. Индификаторы используются в основном для придания одному или нескольким элементам одного класса индивидуальных свойств. Скажем, Вы создали класс blue - синий курсив. Но Вам понадобился жирный подчеркнутый текст синим курсивом. Конечно, можно создать новый класс, но зачем? Проще описать ID. Например "boldunderline". И все элементы класса blue с значением ID "boldunderline" станут жирным подчеркнутым синим курсивом. Произойдет как бы синтез свойств класса blue и идентификатора boldunderline. ПРИМЕР: <html> <head> <title> Пример CSS </title> </head> <style> .blue {color:blue; font-style:italic} #boldunderline {text-decoration:underline; font-weight:bold} </style> <body> <p class="blue"> Здравствуйте, это моя домашняя страница. </p> <p class="blue" id="boldunderline"> Пока еще в стадии разработки ... </p> <p id="boldunderline">... Но скоро откроется </p> </body> </html> Как видно из примера, атрибут ID может быть использован без указания класса (последний параграф примера. Тогда параграф будет обладать только свойствами ID "boldunderline" (в примере - жирный, подчеркнутый текст). Контекстуальные селекторы (Contextual Selectors): Контекстные селекторы - это сочетания нескольких обыкновенных селекторов. Стиль задается только элеметнам в заданной последовательности в зависимости от каскадного порядка. ПРИМЕР: P EM {color:silver;} В данном примере все элементы EM внутри элементов P будут иметь заданный стиль. Придание нескольким элементам одинаковых свойств: Скажем Вам нужно придать нескольким элементам Вашей веб страницы одинаковых свойств. В этом случае при определении селекторы перечисляутся через запятую перед блоком свойств. ПРИМЕР: h1,h2,h3,p,strong {color:green; font-style:italic;} Все элементы h1, h2, h3, p и strong будут зелеными. Псевдоклассы и псевдоэлементы : Синтаксис: Псевдоклассы и псевдоэлементы - это особые классы и элементы, присущие CSS и автоматически определяемые поддерживеющими CSS браузерами. Псевдоклассы различают разные типы одного элемента, создавая при определении собственные стили для каждого из них. Псевдоэлементы являются частями других элементов, задавая этим частям отличный от элемента вцелом стиль. Список псевдоклассов и псевдоэлементов : Anchor Pseudo Classes - эти псевдоклассы элемента <a href=" ">, обозначающего ссылку. Псевдоклассы этого элемента: (ссылка), active (активная ссылка), visited (посещенный ранее URL), hover (псевдокласс, возникающий при поднесении курсора к ссылке, не работает в Нетскейпе). First Line Pseudo-element - first-line. Этот псевдоэлемент может быть использован с block-level элементами (p, h1 и т.д.). Он изменяет стиль первой строки этих элементов. First Letter Pseudo-element - first-letter. Похож на first-line, но влияет не на всю строку, а только на первый символ. ПРИМЕР : a:link,a:visited {color:blue} a:active {color:red} a:hover {text-decoration:none} В данном примере все элементы Anchor (ссылки) будут синими. При нажатии (в активном состоянии) поменяют цвет на красный. И при подведении курсора мышки исчезнет подчеркивание. Примечание : описания нескольких свойств для одного селектора, контекстуального селектора, класса, индивидуально именованного стиля или группы объедененных селекторов отделяются друг от друга точкой с запятой ";". Внутренние Таблицы Стилей Как уже говорилось, использование Внутренних стилей мало чем отличается от использования обычных HTML тегов. Они задают стиль только одному элементу документа при помощи атрибута STYLE в HTML теге. ПРИМЕР HTML: <font color="blue" size="3" face="Arial"> Вперед в будущее </font> ПРИМЕР INLINE STYLE SHEET: <font style="color:blue; font-size:12pt; font-family:Arial"> Вперед в будущее </font> Как можно заметить, код Inline Style Sheet получился больше чем HTML. Поэтому ISS следует использовать только если необходимо задать определенному элементу свой индивидуальный стиль, существующий в классификации CSS и нереализованный в HTML. Или же при необходимости абсолютно позиционировть данный элемент. Глобальные Таблицы Стилей Глобальные стили задают вид элементов всего документа. Для этого используется тег <STYLE type="text/css">. Он размещается в заголовке документа. ПРИМЕР: <html> <head> <title> Пример Глобальных Таблиц Стилей </title> </head> <STYLE type="text/css"> h1{color:red; font-style:italic; font-size:32px} .blue{color:blue} #bold{font-weight:bold} </STYLE> <body> <h1> Этот заголовок написан крупным красным курсивом </h1> Вот <font class="blue"> это </font> слово - синие, a <font id="bold"> это</font> - жирное. </body> </html> В данном примере все элементы H1 будут написаны крупным красным курсивым, все элементы с указанным классом BLUE будут синими , а все элементы с идентификатором ID="Bold" станут жирными. Для простоты вместо <STYLE type="text/css"> можно использовать просто тег <STYLE>, что менее граммотно. Связанные Таблицы Стилей Связанные таблицы стилей используются для придания нескольким документам одного стиля и xранятся в отдельном файле. Это очень привлекательно, когда нужно выдержать сайт в одном стиле, не утруждая себя составлением таблиц для каждого документа. ПРИМЕР: Файл styles.css <STYLE type="text/css"> body {background:black; font-size:9pt; color:red; font-family:Arial Black} .base{color:blue; font-style:italic} h1 {color:white} #bold {font-weight:bold} </STYLE> В самих же HTML документах делается ссылка на этот файл при помощи тега <LINK>. Выглядит это так: <LINK rel="STYLESHEET" TYPE="text/css" HREF="путь до файла"> ПРИМЕР: Файл Index.html <html> <head> <title> Просто еще один пример </title> </head> <LINK rel="stylesheet" type="text/css" href="styles.css"> <body> Содержание Документа </body> </html> На этом я заканчиваю первую часть руководства и перехожу ко второй части. Часть Il. Cвойства CSSСвойства Font
Возможные значения: *Применимо для: всех элементов Описание: это свойство определяет используемый элементом шрифт. Если указать URL, то шрифт автоматически установится на компьютер пользователя ПРИМЕР: font-family:Arial Black URL('arialblack.ttf')
Возможные значения: *Применимо для: всех элементов Описание: стиль элемента. Курсивный или обычный ПРИМЕР: font-style:italic
Возможные значения: *Применимо для: всех элементов Описание: варианты отображения шрифта. Нетскейп не поддерживает это свойство ПРИМЕР: font-variant:small-caps
Возможные значения: *Применимо для: всех элементов Описание: выделение (жирность) элемента ПРИМЕР: font-weight:bold
Возможные значения: *Применимо для: всех элементов Описание: размер шрифта ПРИМЕР: font-size:30pt
Возможные значения: *Применимо для: всех элементов Описание: обобщает вышеперечисленные свойства ПРИМЕР: font: italic bolder Arial 12pt Свойства Text
Возможные значения: *Применимо для: всех элементов Описание: расстояние между cловами. Не работает ни в Нетскейпе, ни в MSIE ПРИМЕР: word-spacing:0.4em text-decoration Возможные значения: *Применимо для: всех элементов Описание: "украшение" текста ПРИМЕР: text-decoration:line-through
Возможные значения: *Применимо для: всех элементов Описание: расстояние между буквами. Не работает в Нетскейпе ПРИМЕР: letter-spacing:100
Возможные значения: *Применимо для: inline элементов Описание: позиционирование элементов по отношению к другим элементам стоящих в одном ряду. Не работает в Нетскейпе ПРИМЕР: vertical-align:top-text
Возможные значения: *Применимо для: inline элементов Описание: изменение текста. Не работает в Нетскейпе ПРИМЕР: text-transform:Capitalize
Возможные значения: *Применимо для: block-level элементов Описание: положение текста ПРИМЕР: text-align:right
Возможные значения: *Применимо для: block-level элементов Описание: отступ ПРИМЕР: text-indent:30 em
Возможные значения: *Применимо для: всех элементов Описание: отступ сверху ПРИМЕР: line-height:100% Свойства Color и Background
Возможные значения: *Применимо для: всех элементов Описание: цвет ПРИМЕР: color:#f00000
Возможные значения: *Применимо для: всех элементов Описание: цвет фона элемента ПРИМЕР: background-color:#f00000
Возможные значения: *Применимо для: всех элементов Описание: фоновое изображение ПРИМЕР: background-image:URL(cool.gif)
Возможные значения: *Применимо для: всех элементов Описание: повторения фонового изображения ПРИМЕР: background-repeat:no-repeat
Возможные значения: *Применимо для: всех элементов Описание: возможность прокрутки фонового изображения ПРИМЕР: background-attachment:fixed
Возможные значения: *Применимо для: block-level и replaced элементов Описание: положение фонового изображения (работает с background-repeat равным repeat-x, repeat-y или no-repeat) ПРИМЕР: background-position:50%0%
Возможные значения: *Применимо для: всех элементов Описание: обобщает вышеперечисленные свойства ПРИМЕР: background:no-repeat black fixed 50%0% Свойства Box
Возможные значения: *Применимо для: всех элементов Описание: определяет отступ сверху ПРИМЕР: margin-top:100
Возможные значения: *Применимо для: всех элементов Описание: определяет отступ справа ПРИМЕР: margin-right:100%
Возможные значения: *Применимо для: всех элементов Описание: определяет отступ снизу ПРИМЕР: margin-bottom:100em
Возможные значения: *Применимо для: всех элементов Описание: определяет отступ слева ПРИМЕР: margin-left:100pt
Возможные значения: *Применимо для: всех элементов Описание: обобщает все вышеперечисленные свойства ПРИМЕР: background:100pt
Возможные значения: *Применимо для: осех элементов Описание: отступ от верхнего border'а ПРИМЕР: padding-top:100pt
Возможные значения: *Применимо для: всех элементов Описание: отступ от правого border'а ПРИМЕР: padding-right:100%
Возможные значения: *Применимо для: всех элементов Описание: отступ от нижнего border'а ПРИМЕР: padding-bottom:100em
Возможные значения: *Применимо для: всех элементов Описание: отступ от левого border'а ПРИМЕР: padding-top:100
Возможные значения: *Применимо для: всех элементов Описание: обобщает вышеперечисленные свойства. Можно задать несколько значений одновременно (до четырех) для разных сторон. Если установлено одно значение - задается единый отступ для всех сторон, если два - то задаются различные отступы для прилежащих сторон, а если четыре - то задаются индивидуальные отступы для всех сторон. ПРИМЕР: padding:100px
Возможные значения: *Применимо для: всех элементов Описание: толщина верхнего border'а ПРИМЕР: border-top-width:100pt
Возможные значения: *Применимо для: всех элементов Описание: толщина правого border'а ПРИМЕР: border-right-width:thick
Возможные значения: *Применимо для: всех элементов Описание: толщина нижнего border'а ПРИМЕР: border-bottom-width:100em
Возможные значения: *Применимо для: всех элементов Описание: толщина левого border'а ПРИМЕР: border-left-width:medium
Возможные значения: *Применимо для: всех элементов Описание: толщина border'ов. Можно задать несколько значений одновременно (до четырех) для разных border'ов. Если установлено одно значение - задается единая толщина для всех сторон, если два - то задаются различная толщина для прилежащих сторон, а если четыре - то задаются индивидуальная толщина для всех сторон ПРИМЕР: border-width: 15pt
Возможные значения: *Применимо для: всех элементов Описание: Цвет border'а. Не работает в Нетскейпе ПРИМЕР: border-color:green
Возможные значения: *Применимо для: всех элементов Описание: стиль border'ов. Можно задать несколько значений одновременно (до четырех) для разных border'ов. Если установлено одно значение - задается единый стиль для всех сторон, если два - то задаются различные стили для прилежащих сторон, а если четыре - то задаются индивидуальные стили для всех сторон ПРИМЕР: border-style: dotted groove border-top Возможные значения: *Применимо для: всех элементов Описание: обобщает вышеперечисленные свойства для верхнего border'а ПРИМЕР: border-top: 100em red groove
Возможные значения: *Применимо для: всех элементов Описание: обобщает вышеперечисленные свойства для правого border'а ПРИМЕР: border-right: 5pt magenta solid
Возможные значения: *Применимо для: всех элементов Описание: обобщает вышеперечисленные свойства для левого border'а ПРИМЕР: border-left: 15pc coral inset
Возможные значения: *Применимо для: всех элементов Описание: обобщает вышеперечисленные свойства для нижнего border'а ПРИМЕР: border-bottom: 30 orange outset
Возможные значения: *Применимо для: всех элементов Описание: обобщает вышеперечисленные свойства ПРИМЕР: border: thik black double
Возможные значения: *Применимо для: block-level и replaced элементов Описание: ширина элемента ПРИМЕР: width:10%
Возможные значения: *Применимо для: block-level и replaced элементов Описание: высота элемента ПРИМЕР: height:100pt
Возможные значения: *Применимо для: всех элементов Описание: расположение элемента ПРИМЕР: float:right
Возможные значения: *Применимо для: всех элементов Описание: расположение других элементов вокруг данного ПРИМЕР: clear:both Классификация
Возможные значения: *Применимо для: всех элементов Описание: определяет, как будет отображаться элемент ПРИМЕР: display:none
Возможные значения: *Применимо для: block-level элементов Описание: оприделяет, как будут отображаться пробелы между элементами ПРИМЕР: white-space:nowrap
Возможные значения: *Применимо для: элементов со значением display равным list-item Описание: определяет вид list-item маркера. Если значение list-style-image равно none или не уточнено ПРИМЕР: list-style-type:lower-alpha
Возможные значения: *Применимо для: элементов со значением display равным list-item Описание: задает вид list-item маркера в виде картинки ПРИМЕР: list-style-image:URL(cool.gif)
Возможные значения: *Применимо для: элементов со значением display равным list-item Описание: определяет положение маркера в зависимости от list item элемента ПРИМЕР: list-style-position:inside
Возможные значения: *Применимо для: элементов со значением display равным list-item Описание: обобщает вышеперечисленные свойства ПРИМЕР: list-style:inside Часть III. ДополненияМеры длины Синтаксис: "+" (можно опустить) или "-" затем [число] плюс [единица измерения] (без пропусков) ПРИМЕР: -566pt Единицы длинны : ex - x-height, ширина буквы
"x" используемого элементом шрифта Процентные меры Синтаксис : "+" или "-" затем [число] плюс "%" (без пропусков) ПРИМЕР : -566% Цвета Синтаксис: [color] ПРИМЕР : magenta Значением цвета может быть его название (red , lightgreen, coral и т.д.) или RGB значение Способы выразить цвет в RGB (red green blue) :
Все примеры отображают один и тот же цвет Ссылки Синтаксис: "URL" , потом в скобках приводится ссылка.Ссылку также можно, помимо скобок, заключить в одинарные или двойные кавычки (без пропусков) ПРИМЕР : URL('cool.gif') Послесловие. От АвтораОтмазка : Возможно наличие ошибок и опечаток в этой статье. Все мы люди и незастрахованы от неожиданостей. Если таковые будут Вами замечены - сообщите мне, я их обязательно исправлю. Также можете присылать предложения и дополнения касательно данной статьи. Под MSIE и Нетскейпом подразумиваются Microsoft Internet Explorer 4.0+ и Netscape Navigator 4.0+ соответственно. Данная статья является моей
интелектуальной собственностью и защищается
законом РФ об авторском праве. Любое
коммерческое использование материалов данной
статьи без письменного разрешения автора
запрещено. При некоммерческом использовании
ссылка на автора обязательна. |
<Назад>
<Sub Main> <Download
Centre> <Guest Book & Forum> <Contact Info> <Add Links>
|