Виды css. Виды CSS селекторов. Селектор структурных псевдоклассов типа

Селектор в CSS — это указатель на элемент или группу элементов, к которым будут применяется правила стилей. Существуют следующие виды селекторов:

1. Селекторы по тэгам : h1

2. Селектор по id : #main

3. Селекторы по классам : .hidden

4. Селектор по нескольким классам

Записываются слитно без пробелов. Селекторы удовлетворяющие одновременно сразу нескольким условиям (логическое “И”). Стили будут применяться ко всем элементам, которые одновременно имеют и класс.hidden и класс.closed .

Hidden.closed

5. Контекстные селекторы

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

P strong ul .selected .header .menu a

6. Соседние селекторы

Выделяет последующий элемент. Записываются с помощью знака + . Читается как: применить свойства к селектор2 который должен быть сразу после селектор1 .

Стили применяются к элементу, подходящему под селектор2 , только если перед ним расположен элемент, подходящий под селектор1 .

  • ... .green + .selected {}

    В примере.green + .selected применит стили ко второму элементу, т.к. перед ним есть элемент с классом.green . Селектор.green + li тоже применит стили ко второму элементу, а селектор.selected + .green не сработает.

    7. Родственные селекторы

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

    • item

    Selected too

    Not selected ... ul ~ p {}

    В данном примере будут выбраны все элементы p, идущие за ul. В то время, как при использовании селектора ul + p будет выбран только первый элемент.

    8. Дочерние селекторы

    Записываются с помощью знака > и распространяются только на элементы первого уровня вложенности. На элементы вложенные в другие элементы не распространяются.

    Ul > li {}

    В случае контекстных селекторов они влияют на всех потомков (например если задать ul li) что не всегда удобно. Дочерние селекторы позволяют задать стили только для элементов первого уровня вложенности.

    ul > li означает то же, что и ul li , но выбираются только li первого уровня вложенности, которые напрямую являются вложенными в ul. На li вложенные в другие дочерные li элементы, правила уже не будут действовать.

    9. Селекторы атрибутов

    Чаще всего используются при работе с формами. Селекторы атрибутов записываются с использованием квадратных скобок элемент[атрибут] .

    Примеры селекторов атрибутов:

    Input input div a a a a

    В примере выше ~ позволяет выделить определенный атрибут из списка атрибутов, разделенных запятой, например из:

    10. Глобальный селектор

    Селектор * выберет все элементы. Его также можно использовать для выделения дочерних элементов:

    * { margin: 0; padding: 0; } .content * { outline: none; }

    11. Псевдоклассы

    Примеры псевдоклассов:

    A:link a:visited a:active a:hover input:checked .clearfix:after {} div:not(#container) p::first-line p::first-letter

    Псевдокласс отрицания:not бывает очень полезным. Например, когда необходимо выбрать все div, за исключением того, который имеет id container.

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

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

    Хотя с интеграцией CSS 3 селекторов стало еще больше, познакомиться с ними и использовать их по назначению не составит большого труда, потому как все они имеют одну цель - разгрузить HTML код. С ней они справляются настолько хорошо, что для каждого элемента веб- страницы можно использовать несколько видов селекторов. Потому как современный CSS определил для нас довольно широкий арсенал, я разделил данный урок на следующие блоки:

    Создание CSS правил в 2 словах

    Каскадная таблица стилей представляет собой набор CSS правил, каждое из которых призвано форматировать определенный элемент веб-страницы. Само правило состоит из 2 частей:

    1. Селектор
    2. Блок объявлений

    При помощи селектора мы указываем элемент, на который будем воздействовать. С помощью блока объявлений мы задаем параметры для выбранных элементов. Блок объявлений в свою очередь состоит из 2 частей:

    1. Свойство
    2. Значение

    Свойство служит для выбора параметра, который мы будем настраивать.

    Селектор тегов

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

    P {
    font-family: Verdana;
    }

    Если мы захотим принять шрифт Verdana для заголовков первого уровня, будет справедлива следующая запись:

    H1 {
    font-family: Verdana;
    }

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

    Групповой вид селекторов

    Создание одинаковых блоков объявлений для разных тегов не является ошибкой. Однако, для грамотных веб-мастеров подобная запись неприемлема. В примере выше мы придали одинаковый шрифт для 2 тегов, причем сделали это создав два отдельных правила, хотя можно было обойтись и одним. Для этого достаточно перечислить форматируемые теги через запятую:

    P, h1 {
    font-family: Verdana;
    }

    Групповой вид селекторов очень удобен и способен значительно сократить объем css файла. Как уже было сказано до этого, достаточно перечислить форматируемые теги через запятую.

    Универсальный селектор

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

    * {
    font-family: Verdana;
    }

    Селектор классов

    Как видно из названия, при помощи этого вида селекторов мы выбираем элементы по определенным классам. При необходимости в форматировании блочных элементов с классом "container" используется следующая запись:

    Container {
    font-family: Verdana;
    }

    Достаточно прописать точку и название класса. Хочется отметить что все элементы, вложенные в блочный элемент с классом "container" также будут отформатированы.

    Селектор идентификаторов

    Здесь та же история как и с классами. Разница лишь в том что вместо точки мы прописываем - "#". Для форматирования абзаца с id "unique" необходима следующая запись:

    #unique {
    font-family: Verdana;
    }

    Древовидная форма HTML

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

    Для решения этой проблемы будет нелишним освежить память и вспомнить отношения тегов между собой в HTML.


    древовидная форма HTML

    Как видно из иллюстрации выше, тег body является предком для всех остальных тегов. Вложенный в него тег div является его дочерним элементом, сам будучи родителем тегов h2, p и предком тега a. А маркированный список первого уровня имеет 3 дочерних (li, ul) и 2 потомственных элемента (li).

    Все вышеперечисленные теги вписываются в три вида отношений:

    1. предок - потомок
    2. родитель - дочерний элемент
    3. сестринские элементы (теги одного уровня с общим родителем)

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

    Селектор потомков

    В случае необходимости форматирования потомков определённого тега мы пользуемся соответствующим селектором. Например, для форматирования всех вложенных абзацев в блочный элемент (div) используется следующая запись:

    Div p {
    color: blue;
    }

    Вначале мы указываем предка, затем через пробел - потомственный элемент. Запись выше означает: "Отобразите синим цветом все абзацы находящиеся внутри тега div". Для форматирования всех ссылок внутри абзаца мы пишем следующее:

    P a {
    color: red;
    }

    Запись выше означает: "Отобразите красным цветом все ссылки, находящиеся внутри абзацев". Как видите - все очень просто.

    Дочерние селекторы

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

    Все бы хорошо, но это порождает определенные проблемы. "Какие именно?" - спросите вы. Ну, хотя бы то что в случае придания определенных свойств "предку" они унаследуются потомственными элементами. Чтобы мы могли точечно выбирать элементы для форматирования, были придуманы некоторые виды селекторов, в том числе и дочерний.

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

    Info>p {
    font-family: Arial;
    }

    Запись выше означает: "Отобразить шрифтом Arial все абзацы, являющиеся дочерними блоку с классом info". Если же нам нужно выделить дочерние пункты маркированного списка, аналогично пишем следующее:

    Ul>li {
    color: blue;
    }

    Запись выше означает: "Перекрасить все дочерние пункты маркированного списка в синий цвет". Такое правило CSS вполне может пригодиться, ведь внутри одного списка вполне может располагаться другой.

    В некоторых случаях может возникнуть необходимость выделения не всех дочерних элементов, а только некоторых. Для управления первым дочерним элементов необходимо воспользоваться псевдоэлемнтом :first-child

    Wrapper:first-child {
    font-family: Tahoma;
    }

    Правило выше означает: "Отобразить первый дочерний элемент класса "wrapper" шрифтом Tahoma".

    Псевдоэлемент :last-child помогает управлять последним дочерним элементом:

    Wrapper:last-child {
    font-family: Tahoma;
    }

    У нас также есть возможность выбирать любой по счету дочерний элемент при помощи псевдоэлемента :nth-child

    Wrapper:nth-child(even) {
    color: pink;
    }

    Запись выше означает: "Выделить все чётные дочерние элементы класса "wrapper" розовым цветом". Для выделения нечетных элементов even нужно заменить на odd .

    Для выделения каждого 5 элемента необходимо добавить 5n. Если же стоит выделить каждый 4-й элемент начиная с шестого необходимо в скобках указать - 4n+6. Значения в скобках можно менять по-своему усмотрению:

    Wrapper:nth-child(3n+2) {
    border-bottom: 1px solid black;
    }

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

    Псевдоклассы

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

    A:link Отвечает за внешний вид ссылки в спокойном состоянии a:hover Отвечает за внешний вид ссылки в момент наведения на неё курсором мыши a:active Отвечает за внешний вид ссылки в момент нажатия на неё a:visited Отвечает за внешний вид уже посещенной ссылки

    Пример того, как могут быть использованы эти псевдоклассы:

    A:link {
    color: blue;
    }

    a:hover {
    color: orange;
    }

    a:active {
    color: red;
    }

    a:link {
    color: grey;
    }

    Запись выше означает: "Выделить синим цветом ссылки в обычном состоянии. Отображать их оранжевым цветом в момент наведения по ним. Отображать ссылки красного цвета в момент нажатия. Выделить серым цветом уже посещенные ссылки."

    Псевдокласс:hover

    Этот псевдокласс можно использовать не только по отношению к ссылкам, ведь мы можем наводить мышкой на любые другие элементы веб-страницы. Например:

    Img:hover {
    border: 1px solid grey;
    }

    Запись выше означает: "Выделить все изображения рамкой серого цвета в момент наведения по ним." Таким же образом можно настраивать любые другие элементы в момент проведения по ним курсором.

    Псевдоэлементы

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

    P.attention:before {
    content: "Внимание!";
    }

    Запись выше означает: "Добавить слово "Внимание!" перед абзацами с классом attention". Для добавления в конце элемента мы пишем:

    P.attention:after {
    content: "Внимание!";
    }

    Псевдоэлемент :focus помогает управлять внешним видом полей для ввода:

    Input:focus {
    background-color: blue;
    font-style: italic;
    }

    Запись выше означает - "Окрасить фон полей для ввода в синий цвет и использовать курсивное начертание шрифта в момент набора текста".

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

    ::selection {
    color: white;
    background-color: black;
    }

    Правило выше означает: "Отображать фон черным, а цвет шрифта белым в момент выделения текста". Этот селектор незнаком для браузера Firefox, и для решения этой задачи необходимо перед правилом добавить следующее:

    ::-moz-selection {
    color: white;
    background-color: black;
    }

    Дочерние элементы по типу

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

    Например, мы можем выделить первый дочерний нумерованный список блока с классом container:

    Container>ol:first-of-type {
    color: yellow;
    }

    Плюс ко всему мы имеем в распоряжении псевдоэлементы :last-of-type и :nth-of-type , которые имитируют:last-child и:nth-child соответственно.

    #main>h2:last-of-type {
    color: yellow;
    }

    В примере выше мы выделили последний дочерний заголовок второго уровня относящийся к блоку с идентификатором main.

    Селектор смежных элементов

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

    H1+p {
    font: italic 20px Arial;
    }

    Согласно правилу выше, если между заголовком h1 и абзацем окажется что-то ещё, например изображение, то в этом случае тег p не будет отформатирован. Также вместо знака плюс можно использовать ~ (тильда) . При помощи неё будут отформатированы все маркированные списки после заголовка h1:

    H1~ul {
    color: orange;
    }

    Селектор атрибутов

    Используя этот вид селектора можно форматировать элементы выбрав их по атрибуту. Для управления всеми внешними ссылками нужно указать следующее:

    A {
    color: aqua;
    }

    Запись href^="http://" означает что необходимо выделить все ссылки, начинающиеся на http://. Такие css правила имеют место быть, потому что абсолютные адреса в основном используются для внешних ссылок.

    A {
    color: brown;
    }

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

    Img {
    border: 2px dashed grey;
    }

    Знак звездочки помогает выбрать те изображения, которые в своем названии содержат слово boots.

    Для выделения всех изображений, находящихся в блоке с классом relative мы создаем следующее css правило:

    Relative {
    border: 2px dashed grey;
    }

    Псевдокласс отрицания

    Если вам когда-нибудь приходилось иметь дело с движком WordPress, вы должны знать что в ней все ссылки имеют абсолютный вид. Как мы рассматривали выше, при необходимости выделить внешние ссылки можно использовать селектор по атрибуту, те которые начинаются на http://. Как вы понимаете, такой вариант решения вопроса с движком WordPress не прокатит. Но у нас в арсенале есть гениальный псевдокласс отрицания, который мы можем задействовать:

    A:not() {
    border: 2px dashed brown;
    }

    Правило выше означает: "Выделить коричневым цветом все ссылки, начинающиеся на http:// кроме тех, которые начинаются на http://mysite.com". Псевдокласс отрицания можно использовать не только с селекторами атрибутов, но и с другими простыми селекторами.

    Стоит знать что для каждого селектора можно использовать только один псевдокласс отрицания. Следующая запись будет неверной - .container:not(#info):not(h3)

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

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

    На этом я с вами не прощаюсь. Спасибо за внимание и до встречи в следующих публикациях!

    Каскадные таблицы стили CSS (Cascading Style Sheets) – стандарт стилей, объявленный консорциумом W3C. Термин каскадные указывает на возможность слияния различных видов стилей и на наследование стилей внутренними тегами от внешних.

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

    CSS – абстракция, в которой внешний вид Web-документа определяется отдельно от его содержания.


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


    Возможно, Вам понадобятся также:


    По методам добавления стилей в документ различают три вида стилей.

    Внутренние стили

    Внутренние стили определяются атрибутом style конкретных тегов. Внутренний стиль действует только на определенные такими тегами элементы. Этот метод мало отличается от традиционного HTML.

    Пример

    Абзац с текстом синего цвета

    РЕЗУЛЬТАТ:

    Абзац с текстом синего цвета

    Абзац с текстом красного цвета

    Не стоит использовать внутренние стили слишком часто, так как тогда Web-документ оказывается перегружен кодом и его внешний вид трудно изменить.

    Глобальные стили

    Глобальные стили CSS располагаются в контейнере , расположенном в свою очередь в контейнере ... .


    Атрибут type="text/css" , ранее обязательный для тега .........

    Серый цвет текста во всех абзацах Web-страницы

    РЕЗУЛЬТАТ:

    Серый цвет текста во всех абзацах Web-страницы

    Серый цвет текста во всех абзацах Web-страницы

    Внешние (связанные) стили

    Внешние (связанные) стили определяются в отдельном файле с расширением css . Внешние стили позволяют всем страницам сайта выглядеть единообразно.

    Для связи с файлом, в котором описаны стили, используется тег , расположенный в контейнере ... .

    В этом теге должны быть заданы два атрибута: rel="stylesheet" и href , определяющиЙ адрес файла стилей.

    Пример
    ......... ......... .........

    Подключение стилей

    Правило подключения глобальных и внешних стилей состоит из селектора и объявлений стиля .

    Селектор, расположенный в левой части правила, определяет элемент (элементы), для которых установлено правило. Далее, в фигурных скобках перечисляются объявления стиля, разделенные точкой с запятой. Например:

    P { text-indent: 30px; font-size: 14px; color: #666; }

    Объявление стиля – это пара свойство CSS: значение CSS .

    Например: color: red

    При внутреннем подключении стиля правило CSS, которое является значением атрибута style , состоит из объявлений стиля, разделенных точкой с запятой. Например:

    Селекторы CSS

    Селектор Описание Подробнее
    * Любой элемент
    E Элемент, определенный тегом E
    E#myid Элемент E с идентификатором "myid"
    E.myclass Элемент E класса "myclass"
    E Селектор существования атрибута
    E Селектор равенства атрибута
    E Селектор атрибута со списком значений Селекторы атрибутов
    E Селектор префикса атрибута
    E Селектор суффикса атрибута
    E Селектор подстроки атрибута
    E:link Элемент E – еще не посещенная пользователем ссылка Динамические псевдоклассы
    E:visited Элемент E – уже посещенная пользователем ссылка Динамические псевдоклассы
    E:hover Элемент E при наведении на него указателя мышки Динамические псевдоклассы
    E:active Элемент E, активированный пользователем Динамические псевдоклассы
    E:focus Элемент E в фокусе Динамические псевдоклассы
    E:target Элемент E, который является целью ссылки Целевой псевдокласс
    E:lang Элемент E, написанный на указанном языке Псевдокласс языка
    E:enabled Элемент E – доступный элемент формы Псевдоклассы состояний
    E:disabled Элемент E – недоступный элемент формы Псевдоклассы состояний
    E:checked Элемент E – включенный флажок или переключатель Псевдоклассы состояний
    E:indeterminate Элемент E – неопределенный флажок или переключатель Псевдоклассы состояний
    E:root Элемент E, корень документа Структурные псевдоклассы
    E:nth-child(n) Элемент E, n-й ребенок родительского элемента Структурные псевдоклассы
    E:nth-last-child(n) Элемент E, n-й ребенок родительского элемента, считая с конца Структурные псевдоклассы
    E:nth-of-type(n) n-й элемент типа E Структурные псевдоклассы
    E:nth-last-of-type(n) n-й элемент типа E, считая с конца Структурные псевдоклассы
    E:first-child Элемент E, первый дочерний элемент родителя Структурные псевдоклассы
    E:last-child Элемент E, последний дочерний элемент родителя Структурные псевдоклассы
    E:first-of-type Первый элемент типа E Структурные псевдоклассы
    E:last-of-type Последний элемент типа E Структурные псевдоклассы
    E:only-child Единственный у родителя дочерний элемент Структурные псевдоклассы
    E:only-of-type Единственный у родителя элемент типа E Структурные псевдоклассы
    E:empty Элемент E, не содержащий дочерних элементов Структурные псевдоклассы
    E:not(X) Элемент E, который не соответствует простому селектору X Псевдокласс отрицания
    E::first-line Первая строка элемента E Псевдоэлементы
    E::first-letter Первая буква элемента E Псевдоэлементы
    E::before Содержимое до элемента E Псевдоэлементы
    E::after Содержимое после элемента E Псевдоэлементы
    E::selection Выделение в элементе E Псевдоэлементы
    E F Элемент F, который находится внутри элемента E
    E > F Элемент F, который находится непосредственно внутри элемента E
    E + F Элемент F, который следует сразу после элемента E
    E ~ F Элемент F, который следует после элемента E

    Универсальный селектор

    Универсальный селектор соответствует любому элементу html-документа.

    Для обозначения универсального селектора применяется символ "звёздочка" (*).

    Его используют, если надо установить одинаковый стиль для всех элементов Web-страницы. Например:

    * { margin: 0; padding: 0; }

    В некоторых случаях символ "звёздочка" (*) может быть опущен:
    *.myclass и .myclass эквиваленты,
    *#myid и #myid эквивалентны

    Селекторы тегов

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

    H1 {color: red; text-align: center;}

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

    H1, h2, h3, h4 {color: red; text-align: center;}

    Селекторы идентификаторов

    HTML предоставляет возможность присвоить уникальный идентификатор любому тегу. Идентификатор задается атрибутом id . Например:

    ...

    Значение идентификатора должно начинаться с латинской буквы и может содержать буквы (,), цифры (), "дефисы" (-) и "подчеркивания" (_).

    Значения всех атрибутов id в html-документе обязаны быть уникальными. Если встречаются id с одинаковыми значениями, то эти идентификаторы игнорируются, а код Web-страницы становится невалидным.

    В CSS-коде селектор идентификатора обозначается знаком "решетка" (#). Так как идентификатор id применяется только к уникальным элементам, название тега перед знаком "решетка" (#) обычно опускают:

    Div#a1 {color: green;}

    аналогично

    #a1 {color: green;}

    Желательно использовать id не для стилевого оформления элемента, а для обращения к нему через скрипты или перехода по ссылке.

    Селекторы классов

    Для стилевого оформления чаще всего используются селекторы классов. Класс для тега задается атрибутом class . Например:

    ...

    Имя класса должно начинаться с латинской буквы и может содержать буквы (,), цифры (), "дефисы" (-) и "подчеркивания" (_).

    Если атрибут id применяется для уникальной идентификации, то при помощи атрибута class тег относят к той или иной группе.

    В CSS-коде селектор идентификатора обозначается знаком "точка" (.). Разные теги можно отнести к одному классу. В таком случае имя тега перед знаком "точка" (.) опускают:

    I.green {color: #008000;} b.red {color: #f00;} .blue {color: #00f;}

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

    ...

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

    Селекторы атрибутов

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


    h1 {color: #800000;} /* элемент h1, у которого есть атрибут title */
    input { border: 1px solid #ссс; padding: 4px 6px; width: 300px; }
    a { text-decoration: none; border-bottom: 1px solid #06c; color: #06c; }
    span { display: inline-block; background-image: url("/img/icon_sprite.png"); }
    a, a { background: url("pic.gif") bottom left no-repeat; display: inline-block; width: 32px; }
    { display: block; float: left; width: 280px; }

    Между именем тега и квадратной скобкой ([) не должно быть пробела!


    Универсальный селектор, селекторы тегов, идентификаторов, классов и атрибутов, а также псевдоклассы относятся к простым селекторам.

    Простые селекторы можно связать в определенные последовательности на основе отношений элементов в дереве Web-документа. Такие конструкции называют комбинаторами.

    Контекстные селекторы

    Один из самых часто используемых комбираторов – контекстный селектор.

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

    Пример
    1. Пушкин А.С.
      • «Выстрел»
      • «Метель»
      • «Дубровский»
    2. Гоголь Н.В.
      • «Ревизор»
      • «Тарас Бульба»
      • «Мертвые души»
    3. Толстой Л.Н.
      • «Война и мир»
      • «Анна Каренина»
      • «Воскресение»

    РЕЗУЛЬТАТ:

    1. Пушкин А.С.
      • «Выстрел»
      • «Метель»
      • «Дубровский»
    2. Гоголь Н.В.
      • «Ревизор»
      • «Тарас Бульба»
      • «Мертвые души»
    3. Толстой Л.Н.
      • «Война и мир»
      • «Анна Каренина»
      • «Воскресение»

    Дочерние селекторы

    Дочерний селектор определяет элемент, который находится внутри другого непосредственно. В дочернем селекторе простые селекторы разделены знаком "больше" (>).

    Пример
    1. Пушкин А.С.
      • «Выстрел»
      • «Метель»
      • «Дубровский»
    2. Гоголь Н.В.
      • «Ревизор»
      • «Тарас Бульба»
      • «Мертвые души»
    3. Толстой Л.Н.
      • «Война и мир»
      • «Анна Каренина»
      • «Воскресение»

    РЕЗУЛЬТАТ:

    1. Пушкин А.С.
      • «Выстрел»
      • «Метель»
      • «Дубровский»
    2. Гоголь Н.В.
      • «Ревизор»
      • «Тарас Бульба»
      • «Мертвые души»
    3. Толстой Л.Н.
      • «Война и мир»
      • «Анна Каренина»
      • «Воскресение»

    Соседние селекторы

    Соседний селектор определяет знак "плюс" (+), разделяющий две последовательности простых селекторов. Элементы, представленные этими последовательностями, находятся внутри одного контейнера и следуют второй за первым непосредственно, не разделенные никакими другими тегами.

    Пример

    РЕФЛЕКСОТЕРАПИЯ

    РЕЗУЛЬТАТ:

    РЕФЛЕКСОТЕРАПИЯ

    Смежные селекторы

    Смежный селектор определяет знак "тильда" (~), разделяющий две последовательности простых селекторов. Элементы, представленные этими последовательностями, находятся внутри одного контейнера и следуют второй за первым (необязательно непосредственно).

    Пример

    РЕФЛЕКСОТЕРАПИЯ

    "Все акты сознательной и бессознательной жизни по способу происхождения суть рефлексы". И.М. Сеченов


    Рефлексотерапия – лечение заболеваний через управление рефлексами. Успешно применяется в программах комплексного лечения или как индивидуальная методика.

    РЕЗУЛЬТАТ:

    РЕФЛЕКСОТЕРАПИЯ

    "Все акты сознательной и бессознательной жизни по способу происхождения суть рефлексы". И.М. Сеченов

    Рефлексотерапия – лечение заболеваний через управление рефлексами. Успешно применяется в программах комплексного лечения или как индивидуальная методика.



    Всего существует семь типов селекторов. Это:

    • Селектор тэга
    • Селектор класса
    • Селектор id
    • Универсальный селектор
    • Селектор атрибута
    • Селектор псевдокласса
    • Селектор псевдоэлемента

    Самый простой – он записывается, как название тэга без угловых скобок. Например, div .

    Данной записью мы говорим, что все содержимое всех тэгов

    нашего документа или документов будет написано шрифтом красного цвета.

    Если нам нужно какому-то одному параграфу задать какой-то, допустим, фон. То мы можем использовать селектор класса. Но перед тем, как писать правила, нам нужно в тэге

    Данного параграфа написать атрибут class , в значении которого можно писать все, что угодно (помимо латинских букв, можно использовать знак дефиса и цифры), но нужно дать название нашему селектору так, чтобы потом было самому понятно, к чему он относится. Затем в таблице стилей, либо в тэге нашего документа между мы пишем точку, а после нее значение атрибута class , и в фигурных скобках задаем правила для данного параграфа.
    Если в документе:

    То
    в таблице стилей:

    Pravilo {

    }

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

    Первое, о чем стоит сказать – это то, что значение атрибута id в HTML – уникальное. В отличие от class, мы не можем его приписать любому тэгу, а только одному! В таблице стилей он изображается в виде знака решетки, а в документе нужно к тэгу добавить атрибут id с каким-то значением.
    Если в документе:

    То
    в таблице стилей:
    #pravilo{

    }

    Универсальный селектор записывается, как "звездочка". Если в таблице задать правила для этого селектора, то это правило будет применяться к содержимому всех тэгов.
    *{

    }

    Все эти четыре типа селекторов работают на сегодняшний день во всех браузерах. Но есть селекторы, которые работают не везде, например, в Internet Explorer версий 7,6 и ниже.

    Записываются они так:

    {

    }

    Этой записью мы говорим, что все, что заключено в тэги, имеющие атрибут title , будет иметь такой вид, который прописан в фигурных скобках. Причем абсолютно не важно, имеет ли этот атрибут какое-нибудь значение. Он может быть пустым и записан так:

    Все равно к тэгу

    Будут применены правила, которые записаны в селекторе .
    Если нужно, чтобы правила были применены к атрибуту (например, к title ) с определенным значением, тогда следует записать так:

    {

    }

    Если нужно, чтобы правила были применены к содержимому определенного тэга с каким-то атрибутом (например, с title ), имеющим определенное значение, то надо записать так:

    p {

    }

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

    {

    }

    title (или другой), в значении которого встречается не слово целиком, а просто какой-то кусочек текста (например, в слове каспийский содержится каспий). Тогда нужно записать так:

    {

    }

    Если мы хотим, чтобы правила были применены к содержимому тэга, имеющего атрибут title (или другой), значение которого начинается с каких-то символов (букв). Тогда нужно записать так:

    {

    }

    Если мы хотим, чтобы правила были применены к содержимому тэга, имеющего атрибут title (или другой), значение которого заканчивается какими-то символами (буквами). Тогда нужно записать так:

    {

    }

    Селекторы атрибутов – это очень мощный инструмент, который, к сожалению сейчас не так широко используется, "благодаря" Microsoft и его IE 6,7 и ниже. Но, в скором времени, когда отомрет окончательно IE версиий 6,7 и ниже, данные селекторы прочно войдут в CSS и будут широко применяться.

    Селекторы псевдоклассов отвечают за вид содержимого элементов, когда оно находится в каком-то состоянии.
    Это селекторы:link, :visited, :active, :hover, :focus и:first-child. Первые два относятся только к ссылкам, т.е. к содержимому тэгов
    , а остальные могут быть применены к любому тэгу, который имеет содержание.

    :link оформляет нетронутые пользователем ссылки.

    a:link {color:blue}

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

    a:visited {color:red;}

    :active оформляет активный элемент (в момент клика мышкой). Может применяться к любому элементу, но в IE 6 работает только для гиперссылок.

    p:active {color:red}

    Этой записью мы говорим, что все параграфы в момент клика по ним мышкой будут окрашены в красный цвет (буквы).

    :hover – оформляет элемент, когда на него пользователь наводит мышкой. Также может применяться к любым элементам, но в IE 6 работает только для гиперссылок.

    p:focus {color:red;}

    При нажатии на Tab текст в элементах будет красного цвета

    :first-child – задает правила для первых "детей" всех элементов. В IE 6 не работает.
    Подробнее о том, что такое дети и родители мы поговорим в другой статье, а сейчас просто скажу то, что тэг, который находится внутри другого тэга, является его "ребенком". Например, у нас есть код:

    При просмотре в браузере содержимое первого тэга

    Окрасится в красный цвет.

    Селекторов псевдоэлементов всего два. Это:first-line и:first-letter
    :first-line – первая линия (строка)
    :first-letter – первый символ
    Если записать:

    p:first-line {color:blue}, то

    во всех параграфах документа или документов первые строки окрасятся в синий цвет.

    Если записать:

    p:first-letter {color:blue}, то

    во всех параграфах первые буквы окрасятся в синий цвет.
    Оба этих селектора не работают в браузере IE 6.

    Вот вроде бы и все о селекторах, если что-то упустил или где-то допустил ошибку - пишите в комментариях к материалу.