CSS Selector

❮ Назад Дальше ❯


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

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

СелекторПримерПример описания
.class.introВыбор всех элементов с
#id#firstnameВыбор элемента с
**Выбор всех элементов
elementpВыбор всех элементов <p>
element,elementdiv, pВыбор всех элементов <div> и всех элементов <p>
element elementdiv pВыбор всех <p> элементов внутри элементов <div>
element>elementdiv > pВыбор всех элементов <p>, в которых родительский элемент является элементом <div>
element+elementdiv + pВыбор всех <p> элементов, помещенных сразу после <div> элементов
element1~element2p ~ ulВыбор каждого элемента <ul>, которому предшествует элемент <p>
[attribute][target]Выбор всех элементов с целевым атрибутом
[attribute=value][target=_blank]Выбор всех элементов с target=»_blank»
[attribute~=value][title~=flower]Выделяет все элементы с атрибутом title, содержащим слово «flower»
[attribute
|=value]
[lang|=en]Выбор всех элементов со значением атрибута lang, начиная с «en»
[attribute^=value]a[href^=»https»]Выбирает каждый элемент <a>, значение атрибута href которого начинается с «https»
[attribute$=value]a[href$=». pdf»]Выбирает каждый элемент <a>, значение атрибута href которого заканчивается «.pdf»
[attribute*=value]a[href*=»html5css.ru»]Выбирает каждый элемент <a>, значение атрибута href которого содержит подстроку «html5css.ru»
:activea:activeВыбор активной ссылки
::afterp::afterВставка чего-либо после содержимого каждого элемента < p >
::beforep::beforeВставка чего-либо перед содержимым каждого элемента <p>
:checkedinput:checkedВыбор каждого отмеченного <input> элемента
:disabledinput:disabledВыбор всех отключенных элементов <input>
:emptyp:emptyВыбор каждого элемента <p>, не имеющего дочерних элементов (включая текстовые узлы)
:enabledinput:enabledВыбор всех включенных элементов <input>
:first-childp:first-childВыбирает каждый элемент <p>, являющийся первым дочерним элементом родительского элемента
::first-letterp::first-letterВыбор первой буквы каждого элемента <p>
::first-linep::first-lineВыбор первой строки каждого элемента <p>
:first-of-typep:first-of-typeВыбор каждого элемента <p>, являющегося первым элементом <p> родительского элемента
:focusinput:focusВыбор элемента ввода, имеющего фокус
:hovera:hoverВыбор ссылок при наведении указателя мыши
:in-rangeinput:in-rangeВыбор входных элементов со значением в указанном диапазоне
:invalidinput:invalidВыбор всех входных элементов с недопустимым значением
:lang(language)p:lang(it)Выбирает каждый элемент <p> с атрибутом lang, равным «it» (Итальянский)
:last-childp:last-childВыбирает каждый элемент <p>, являющийся последним дочерним элементом родительского элемента
:last-of-typep:last-of-typeВыбирает каждый элемент <p>, являющийся последним <p> элементом его родительского элемента
:linka:linkВыбор всех непосещаемых ссылок
:not(selector):not(p)Выбор каждого элемента, не являющегося элементом <p>
:nth-child(n)p:nth-child(2)Выбирает каждый элемент <p>, являющийся вторым дочерним элементом родительского элемента
:nth-last-child(n)p:nth-last-child(2)Выбирает каждый элемент <p>, являющийся вторым дочерним элементом родительского объекта, считая от последнего дочернего элемента
:nth-last-of-type(n)p:nth-last-of-type(2)Выбирает каждый элемент <p>, являющийся вторым элементом <p> родительского элемента, считая от последнего дочернего элемента
:nth-of-type(n)p:nth-of-type(2)Выбор каждого элемента <p>, являющегося вторым элементом <p> родительского элемента
:only-of-typep:only-of-typeВыбор каждого элемента <p>, являющегося единственным элементом <p> родительского элемента
:only-childp:only-childВыбирает каждый элемент <p>, являющийся единственным дочерним элементом родительского элемента
:optionalinput:optionalВыбор входных элементов без атрибута «обязательный»
:out-of-rangeinput:out-of-rangeВыбор входных элементов со значением за пределами заданного диапазона
:read-onlyinput:read-onlyВыбор входных элементов с указанным атрибутом «ReadOnly»
:read-writeinput:read-writeВыбор входных элементов с атрибутом «ReadOnly» не указан
:requiredinput:requiredВыбор входных элементов с указанным атрибутом «required»
:root:rootВыбор корневого элемента документа
::selection::selectionВыбор части элемента, выбранной пользователем
:target#news:targetВыбор текущего активного элемента #news (щелчок по URL-адресу, содержащему это имя привязки)
:validinput:validВыбор всех входных элементов с допустимым значением
:visiteda:visitedВыбор всех посещенных ссылок

❮ Назад Дальше ❯

Селекторы — Справочник CSS

❮ Назад Вперед ❯


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

Используйте наш CSS Тестер Селектора продемонстрировать различные селекторы.

СелекторПримерОписание
.class.introВыделяет все элементы с
#id#firstnameВыделяет все элементы с
**Выделяет все элементы
элементpВыделить все элементы <p>
элемент,элементdiv, pВыделить все элементы <div> и <p>
элемент элементdiv pВыделить все элементы <p> внутри элементов <div>
элемент>элементdiv > pВыделить все элементы <p> где родителем является элемент <div>
элемент+элементdiv + pВыделить все элементы <p> которые размещаются сразу после элементов <div>
элемент1~элемент2p ~ ulВыделить каждый элемент <ul> которые размещаются сразу перед элементом <p>
[атрибут][target]Выделяет все элементы с атрибутом target
[атрибут=значение][target=_blank]Выделяет все элементы с target=»_blank»
[атрибут~=значение][title~=flower]Выделяет все элементы с атрибутом title, содержащие слово «flower»
[атрибут|=значение][lang|=en]Выделяет все элементы со значением атрибута lang, начиная с «en»
[атрибут^=значение]a[href^=»https»]Выбирает каждый элемент <a>, значение атрибута href который начинается с «https»
[attribute$=значение]a[href$=». pdf»]Выбирает каждый элемент <a>, значение атрибута href который заканчивается на «.pdf»
[атрибут*=значение]a[href*=»schoolsw3″]Выбирает каждый элемент <a>, значение атрибута href которого содержит подстроку «schoolsw3»
:activea:activeВыбор активной ссылки
::afterp::afterВставляет что-нибудь после содержимого каждого элемента <p>
::beforep::beforeВставить что-то перед содержимым каждого элемента <р>
:checkedinput:checkedВыбирает каждый проверенный элемент <input>
:disabledinput:disabledВыбрать каждый отключенный элемент lt;input>
:emptyp:emptyВыбирает каждый элемент <p>, у которого нет дочерних элементов (включая текстовые узлы)
:enabledinput:enabledВыбирает каждый включенный элемент <input>
:first-childp:first-childВыбирает каждый элемент <p>, который является первым дочерним элементом родительского элемента
::first-letterp::first-letterВыбирает первую букву каждого элемента <p>
::first-linep::first-lineВыбирает первую строку каждого элемента <p>
:first-of-typep:first-of-typeВыбирает каждый элемент <p>, который является первым элементом <p> своего родителя
:focusinput:focusВыбирает элемент ввода, имеющего фокус
:hovera:hoverВыделяет ссылки при наведении курсора мыши
:in-rangeinput:in-rangeВыделяет входные элементы со значением в заданном диапазоне
:invalidinput:invalidВыбирает все входные элементы с недопустимым значением
:lang(language)p:lang(it)Выбирает каждый элемент <p> с атрибутом lang, равным «it» (итальянский)
:last-childp:last-childВыбирает каждый элемент <p>, который является последним дочерним элементом родительского элемента
:last-of-typep:last-of-typeВыбирает каждый элемент <p>, который является последним элементом <p> своего родителя
:linka:linkВыделяет все непосещенные ссылки
:not(selector):not(p)Выбирает каждый элемент, который не является элементом <p>
:nth-child(n)p:nth-child(2)Выбирает каждый элемент <p>, который является вторым дочерним элементом родительского элемента
:nth-last-child(n)p:nth-last-child(2)Выбирает каждый элемент <p>, который является вторым дочерним элементом родительского элемента, считая от последнего дочернего элемента
:nth-last-of-type(n)p:nth-last-of-type(2)Выбирает каждый элемент <p>, который является вторым элементом <p> своего родителя, считая от последнего потомка
:nth-of-type(n)p:nth-of-type(2)Выбирает каждый элемент <p>, который является вторым элементом <p> своего родителя
:only-of-typep:only-of-typeВыбирает каждый элемент <p>, который является единственным элементом <p> родительского элемента
:only-childp:only-childВыбирает каждый элемент <p>, который является единственным дочерним элементом родительского элемента
:optionalinput:optionalВыбирает элементы ввода без атрибута «required»
:out-of-rangeinput:out-of-rangeВыбирает входные элементы со значением вне указанного диапазона
:read-onlyinput:read-onlyВыбирает входные элементы с указанным атрибутом «readonly»
:read-writeinput:read-writeВыбирает входные элементы с не указанным атрибутом «readonly»
:requiredinput:requiredВыбирает входные элементы с указанным атрибутом «required»
:root:rootВыбирает корневой элемент документа
::selection::selectionВыделяет часть элемента, выбранную пользователем
:target#news:targetВыбирает текущий активный элемент #news (при щелчке по URL, содержащему имя привязки)
:validinput:validВыбирает все входные элементы с допустимым значением
:visiteda:visitedВыбирает все посещенные ссылки

❮ Назад Вперед ❯

CSS селекторы, свойства, значения

Каскадная таблица стилей состоит из CSS правил. Каждое CSS правило состоит из селектора и блока декларации.

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

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

Каждая декларация состоит из имени свойства и его значения, разделенных двоеточием.

Свойства – это ключевые слова, такие как color, font-weight или background-color, которым присвоены определенные значения:

body {
   font-size: 0.8em;
   color: navy;
}

В данном примере создается CSS селектор body, который соотносится с HTML тегом <body>. В этом селекторе определяется два свойства – font-size и color, которым присваиваются соответствующие значения. Таким образом, если этот стиль подключить к HTML документу, то текст внутри элемента <body> (что на самом деле весь контент в основном окне браузера) будет отображаться шрифтом размером 0. 8em и темно-синим цветом.

CSS селекторы можно разделить на пять категорий:

  • Простые селекторы (элементы отбираются по имени, идентификатору или классу)
  • Комбинированные селекторы (элементы отбираются по специфическим отношениям между ними)
  • Селекторы псевдоклассов (элементы отбираются по определенному состоянию)
  • Селекторы псевдоэлементов (отбирается и стилизуется часть элемента)
  • Селекторы атрибутов (элементы отбираются по атрибутам или значениям атрибутов)

CSS селектор элемента

Селектор элемента или HTML селектор — это простой селектор, который отбирает HTML элементы по их имени.

В следующем примере отбираются все существующие на странице элементы <p>. Их текст будет красного цвета и выровнен по центру:

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

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

CSS селектор идентификатора

Селектор идентификатора для отбора заданного элемента использует атрибут id HTML элемента.

Идентификатор элемента уникален в пределах веб-страницы, таким образом селектор идентификатора используется для выбора одного уникального элемента!

Чтобы определить селектор идентификатора, нужно написать символ решетки (#) и имя идентификатора элемента.

В следующем примере определяются стили для HTML элемента с идентификатором:

#para1 {
  text-align: center;
  color: red;
}

Внимание! Имя идентификатора не может начинаться с цифры!

CSS селектор класса

Селектор класса для отбора заданного элемента использует атрибут class HTML элемента.

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

В следующем примере все HTML элементы с классом будут отображать текст красного цвета, который выровнен по центру:

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

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

В следующем примере только элементы <p> с классом будут отображать текст красного цвета, который выровнен по центру:

p.center {
  text-align: center;
  color: red;
}

Также, HTML элементы могут иметь больше одного класса.

В следующем примере элемент <p> будет принимать стили, соответствующие селекторам класса и:

<style>
p.center {
  text-align: center;
  color: red;
}
p.large {
  font-size: 300%;
}
</style>
<p>Этот параграф определен по двум классам.</p>

Внимание! Имя класса не может начинаться с цифры!

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

Универсальный селектор (*) отбирает абсолютно все HTML элементы на странице.

Следующее CSS правило окажет воздействие на каждый HTML элемент на странице:

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

Группирование селекторов

Группирование селекторов позволяет объединить одно и то же определение стиля для нескольких HTML элементов в одну декларацию.

Посмотрите на следующий код CSS (для элементов h2, h3 и p заданы одинаковые стили):

h2 {
  text-align: center;
  color: red;
}
h3 {
  text-align: center;
  color: red;
}
p {
  text-align: center;
  color: red;
}

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

Чтобы сгруппировать селекторы, нужно в головной части перечислить их через запятую.

В следующем примере мы группируем селекторы из предыдущего примера:

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

селекторов CSS — CSS: Каскадные таблицы стилей

Селекторы CSS определяют шаблон для выбора элементов, к которым затем применяется набор правил CSS.

Примечание:

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

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

Универсальный переключатель

Выбирает все элементы. При желании его можно ограничить определенным пространством имен или всеми пространствами имен.

Синтаксис: * нс|* *|*

Пример: * будет соответствовать всем элементам документа.

Селектор типа

Выбирает все элементы с заданным именем узла.

Синтаксис: имя элемента

Пример: input будет соответствовать любому элементу .

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

Выбирает все элементы, имеющие заданный атрибут класса .

Синтаксис: .classname

Пример: .index будет соответствовать любому элементу, имеющему class="index" .

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

Выбирает элемент на основе значения его id атрибут. В документе должен быть только один элемент с заданным идентификатором.

Синтаксис: #idname

Пример: #toc будет соответствовать элементу с id="toc" .

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

Выбирает все элементы, имеющие данный атрибут.

Синтаксис: [атрибут] [атрибут=значение] [атрибут~=значение] 9=значение] [атрибут$=значение] [атрибут*=значение]

Пример: [autoplay] будет соответствовать всем элементам, для которых установлен атрибут autoplay (любое значение).

Список выбора

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

Синтаксис: А, В

Пример: div, span будет соответствовать элементам и

.

Комбинатор потомков

Комбинатор » » (пробел) выбирает узлы, являющиеся потомками первого элемента.

Синтаксис: А Б

Пример: div span будет соответствовать всем элементам , которые находятся внутри элемента

.

Детский комбинатор

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

Синтаксис: А > В

Пример: ul > li будет соответствовать всем элементам

  • , вложенным непосредственно в элемент
      .

  • Общий комбинатор

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

    Синтаксис: А ~ В

    Пример: p ~ span будет соответствовать всем элементам , следующим за

    , сразу или нет.

    Смежный одноуровневый комбинатор

    Комбинатор + соответствует второму элементу только в том случае, если он непосредственно следует за первым элементом.

    Синтаксис: А + В

    Пример: h3 + p будет соответствовать первому элементу

    , за которым

    следует сразу же элемент .

    Комбинатор колонн Expect behavior to change in the future.»> Экспериментальный

    || Комбинатор выбирает узлы, принадлежащие столбцу.

    Синтаксис: A || Б

    Пример: col || td будет соответствовать всем элементы, принадлежащие области .

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

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

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

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

    :: псевдообъекты, не включенные в HTML.

    Пример: p::first-line будет соответствовать первой строке всех элементов

    .

    Термин «селектор» может относиться к одному из следующих:

    Простой селектор

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

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

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

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

    Пример: a#selected {...}

    Комплексный селектор

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

    Примеры: a#selected > .icon {...} , .box h3 + p {...} , a .icon {...}

    Относительный селектор

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

    Примеры: + div#topic > #reference {...} , > .icon {...}

    Список выбора

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

    Пример: #main, article.heading {...}

    Спецификация
    Селекторы уровня 4

    Подробнее см. таблицы спецификаций псевдоклассов и псевдоэлементов.

    Последнее изменение: , участниками MDN

    Памятка по селекторам CSS — SitePoint

    Что такое селекторы CSS?

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

    Типы CSS-селекторов

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

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

     * {
    цвет: зеленый;
    размер шрифта: 20px;
    высота строки: 25 пикселей;
    } 

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

    Селектор CSS типа элемента

    Также называемый просто «селектор типа», этот селектор должен соответствовать одному или нескольким элементам HTML с одинаковым именем. Таким образом, селектор nav будет соответствовать всем HTML 9.0021 nav элемента, а селектор

    <ул>
  • Вода
  • Сок
  • Кленовый сироп
  • Эта часть страницы состоит из трех основных элементов: два элемента

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

            Также обратите внимание, что стили не будут применяться к элементам внутри

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

              Селектор ID CSS

              Селектор ID объявляется с использованием решётки или символа фунта ( # ), предшествующего строке символов. Строка символов определяется разработчиком. Этот селектор соответствует любому элементу HTML, который имеет атрибут ID с тем же значением, что и у селектора, но без символа решетки.

              Вот пример:

               #контейнер {
              ширина: 960 пикселей;
              поле: 0 авто;
              } 

              Этот CSS использует селектор ID для сопоставления с HTML-элементом, например:

               

              может быть любым элементом HTML. Пока у него есть атрибут ID со значением container , стили будут применяться.

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

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

              В дополнение к проблемам негибкости селекторы ID также имеют проблему очень высокой специфичности.

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

              Селектор классов является наиболее полезным из всех селекторов CSS. Он объявляется точкой перед строкой из одного или нескольких символов. Как и в случае с селектором ID, эта строка символов определяется разработчиком. Селектор класса также соответствует всем элементам на странице, атрибут класса которых имеет то же значение, что и класс, за вычетом точки.

              Возьмем следующий набор правил:

               .box {
              отступ: 20 пикселей;
              поле: 10 пикселей;
              ширина: 240 пикселей;
              } 

              Эти стили будут применяться к следующему элементу HTML:

               

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

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

               

              Комбинатор потомков

              Комбинаторы селекторов CSS объединяют селекторы для точного нацеливания. Селектор потомков или, точнее, комбинатор потомков, позволяет вам комбинировать два или более селектора, чтобы вы могли быть более конкретными в своем методе выбора. Например:

               #container .box {
              плыть налево;
              нижний отступ: 15px;
              } 

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

              Посмотрите на следующий HTML:

               
              <дел> <дел>

              Если мы применим CSS из предыдущего примера к этому разделу HTML, единственным элементом, на который повлияют эти стили, будут первые 9 элементов.0021

              элемент класса box . На элемент
              , имеющий класс box-2 , стили не повлияют. Точно так же второй элемент
              с классом box не будет затронут, поскольку он не находится внутри элемента с идентификатором container .

              Вы должны быть осторожны при использовании комбинатора потомков в вашем CSS. Этот тип селектора, хотя и делает ваш CSS немного более удобным для чтения, может излишне ограничивать ваши стили определенным контекстом — в этом случае стили ограничены рамками внутри 9.0021 #container — что может сделать ваш код негибким.

              Дочерний комбинатор

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

               #container > . box {
              плыть налево;
              нижний отступ: 15px;
              } 

              Это тот же код из примера комбинатора потомков, но вместо пробела мы используем символ «больше» (или правую угловую скобку).

              В этом примере селектор будет соответствовать всем элементам, имеющим класс box и являющимся непосредственными дочерними элементами элемента #container . Это означает, что, в отличие от комбинатора потомков, не может быть другого элемента, обертывающего .box — это должен быть прямой дочерний элемент.

              Вот пример HTML:

               
              <дел> <дел> <дел>

              В этом примере CSS из предыдущего примера кода будет применяться только к первым

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

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

              Комбинатор общего назначения

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

               h3 ~ р {
              нижняя граница: 20px;
              } 

              Этот тип селектора объявляется с использованием символа тильды (~). В этом примере все элементы абзаца (

              ) будут оформлены в соответствии с указанными правилами, но только если они являются одноуровневыми элементами

              . Между 9 могут быть и другие элементы.0021

              и

              , и стили все равно будут применяться.

              Применим приведенный выше CSS к следующему HTML:

                

              Title

              Пример абзаца.

              Пример абзаца.

              Пример абзаца.

              <дел>

              Пример абзаца.

              В этом примере стили будут применяться только к первым трем элементам абзаца. Последний элемент абзаца не является родственным элементу

              , потому что он находится внутри элемента
              .

              Смежный комбинатор родственных элементов

              Селектор, который использует соседний комбинатор одноуровневых элементов, использует символ плюса (+) и почти такой же, как обычный одноуровневый селектор. Разница в том, что целевой элемент должен быть непосредственным братом, а не просто общим братом. Давайте посмотрим, как выглядит код CSS для этого:

               p + p {
              отступ текста: 1.5em;
              нижняя граница: 0;
              } 

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

              Итак, если мы применим этот селектор к следующему HTML:

                

              Title

              Пример абзаца.

              Пример абзаца.

              Пример абзаца.

              <дел>

              Пример абзаца.

              Пример абзаца.

              … стили будут применяться только ко второму, третьему и пятому абзацам в этом разделе HTML.

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

              Селектор атрибутов выбирает элементы на основе наличия и/или значения атрибутов HTML и объявляется с помощью квадратных скобок:

               input[type="text"] {
              цвет фона: #444;
              ширина: 200 пикселей;
              } 

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

                

              Но это не будет соответствовать этому:

                

              Селектор атрибута также может быть объявлен с использованием только самого атрибута без значения, вот так:

               ввод [тип] {
              цвет фона: #444;
              ширина: 200 пикселей;
              } 

              Это будет соответствовать всем элементам ввода с атрибутом типа, независимо от значения.

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

              CSS-селектор псевдокласса

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

               a:hover {
              красный цвет;
              } 

              В этом случае частью псевдокласса селектора является часть :hover . Здесь мы прикрепили этот псевдокласс ко всем якорным элементам (элементы и ). Это означает, что когда пользователь наводит указатель мыши на элемент , свойство color для этого элемента изменится на красный. Этот тип псевдокласса является динамическим псевдоклассом, поскольку он возникает только в ответ на взаимодействие с пользователем — в данном случае на перемещение мыши по целевому элементу.

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

              Другие популярные псевдоклассы включают в себя:

              • :visited : соответствует посещенным ссылкам
              • : target : соответствует элементу, указанному в URL-адресе документа
              • .
              • :first-child : нацелен на первый дочерний элемент
              • :nth-child : выбирает определенные дочерние элементы
              • : пусто : соответствует элементу без содержимого или дочерним элементам
              • :checked : соответствует включенному флажку или переключателю
              • :blank :стилизует пустое поле ввода
              • : включено : соответствует включенному полю ввода
              • : отключено : соответствует отключенному полю ввода
              • : требуется : нацелен на обязательное поле ввода
              • : действительно : соответствует действительному полю ввода
              • : неверный : соответствует недопустимому полю ввода
              • :playing : нацелен на воспроизводимый аудио- или видеоэлемент
              • : is : собственное решение CSS для вложенных стилей
              • :has : Идентичен :is , но отличается специфичностью.
              • :where : синтаксис аналогичен :is() и :where() , но нацелен на элемент, который содержит  набор других

              CSS-селектор псевдоэлементов

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

               .container: перед {
              содержание: "";
              дисплей: блок;
              ширина: 50 пикселей;
              высота: 50 пикселей;
              цвет фона: #141414;
              } 

              В этом примере используется один тип псевдоэлемента — псевдоэлемент :before . Как следует из названия, этот селектор вставляет воображаемый элемент на страницу внутри целевого элемента перед его содержимым.

               

              Руководство по недавно поддерживаемым современным селекторам псевдоклассов CSS — Smashing Magazine

              • Чтение: 11 мин.
              • УСБ, Гиды, Браузеры, Специальные возможности
              • Поделиться в Twitter, LinkedIn
              Об авторе

              Стефани Эклз (Stephanie Eckles) — инженер-программист, ориентированный на интерфейс. Она является автором ModernCSS.dev, который предлагает современные решения старых проблем CSS. Она … Больше о Stephanie ↬

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

              Селекторы псевдокласса — это те, которые начинаются с символа двоеточия « : » и соответствуют состоянию текущего элемента. Состояние может быть связано с деревом документов или в ответ на изменение состояния, например :hover или :checked .

              Несмотря на то, что этот псевдокласс определен в Selectors Level 4, он уже довольно давно поддерживает кроссбраузерность. Псевдокласс any-link будет соответствовать якорной гиперссылке, если она имеет ссылка . Это будет эквивалентно одновременному совпадению :link и :visited . По сути, это может уменьшить ваши стили на один селектор, если вы добавляете базовые свойства, такие как цвет , которые вы хотели бы применить ко всем ссылкам независимо от их статуса посещения.

              : любая ссылка {
                цвет синий;
                смещение подчеркивания текста: 0,05 em;
              }
               

              Важное замечание о специфичности: :any-link победит a в качестве селектора, даже если и расположены ниже в каскаде, поскольку он имеет специфику класса. В следующем примере ссылки будут фиолетовыми:

               :any-link {
                цвет: фиолетовый;
              }
              а {
                красный цвет;
              }
               

              Итак, если вы вводите :any-link , имейте в виду, что вам нужно будет включить его в экземпляры a в качестве селектора, если они будут напрямую конкурировать за специфичность.

              :focus-visible

              Могу поспорить, что одним из самых распространенных нарушений доступности в Интернете является удаление схема для интерактивных элементов, таких как ссылки, кнопки и входные данные форм, для их состояния :focus . Одна из основных целей этого контура — служить визуальным индикатором для пользователей, которые в основном используют клавиатуру для навигации. Видимое состояние фокуса имеет решающее значение в качестве инструмента поиска пути, когда пользователи перемещаются по интерфейсу с помощью вкладок, а также для укрепления того, что является интерактивным элементом. В частности, видимый фокус описан в Критерии успеха WCAG 2.4.11: Внешний вид фокуса (минимум).

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

              Примечание : Дополнительные сведения см. в рабочем проекте спецификации :focus-visible .

              Последние версии браузеров Firefox и Chromium, кажется, теперь обрабатывают :focus-visible при вводе формы в соответствии со спецификацией, в которой говорится, что UA должен удалять стили :focus , когда :focus-visible соответствует. Safari еще не поддерживает :focus-visible , поэтому нам нужно убедиться, что стиль :focus включен в качестве запасного варианта, чтобы избежать удаления контура для доступности.

              Больше после прыжка! Продолжить чтение ниже ↓

              При наличии кнопки и ввода текста со следующим набором стилей посмотрим, что произойдет:

               input:focus,
              кнопка: фокус {
                контур: 2 пикселя сплошного синего цвета;
                смещение контура: 0,25 em;
              }
              ввод: фокус-видимый {
                контур: 2px сплошной прозрачный;
                цвет границы: синий;
              }
              кнопка: фокус: не (: фокус-видимый) {
                контур: нет;
              }
              кнопка: фокус видимый {
                контур: 2px сплошной прозрачный;
                box-shadow: 0 0 0 2px #fff, 0 0 0 4px синий;
              }
               

              Chromium и Firefox

              • input
                Правильное удаление стилей :focus , когда элементы фокусируются с помощью мыши, вместо :focus-visible , что приводит к изменению border-color и скрытию1 контура 9002 при вводе с клавиатуры
              • button
                Не только использует :focus-visible без дополнительного правила для button:focus:not(:focus-visible) , которое удаляет контур на :focus , but will allow visibility of the box-shadow only on keyboard input

              Safari

              • input
                Continues using only the :focus styles
              • button
                This seems чтобы теперь частично соблюдать назначение :focus-visible на кнопке, скрывая стили :focus при нажатии, но по-прежнему показывая стили :focus при взаимодействии с клавиатурой

              Итак, на данный момент рекомендуется продолжать включать стили :focus , а затем постепенно расширять до использования :focus-visible , что позволяет демонстрационный код. Вот вам CodePen для продолжения тестирования:

              См. Pen [Тестирование приложения :focus-visible] (https://codepen.io/smashingmag/pen/MWJZbew) Стефани Эклз.

              См. приложение Pen Testing :focus-visible от Стефани Эклс.

              : фокус внутри

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

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

               . form-group:focus-within label {
                цвет синий;
              }
               

              Это приводит к тому, что метка становится синей, когда ввод находится в фокусе.

              Эта демонстрация CodePen также включает добавление схемы непосредственно в контейнер .form-group :

              См. Pen [Тестирование приложения :focus-within] (https://codepen.io/smashingmag/pen/xxgmREq) Стефани Эклз.

              См. приложение Pen Testing :focus-within от Стефани Эклс.

              :is()

              Также известный как «сопоставление любому» псевдоклассу, :is() может принимать список селекторов, с которыми выполняется попытка сопоставления. Например, вместо того, чтобы перечислять стили заголовков по отдельности, вы можете сгруппировать их в селекторе :is(h2, h3, h4) .

              Несколько уникальных поведений о списке селекторов :is() :

              • Если селектор в списке недействителен, правило будет по-прежнему соответствовать допустимым селекторам. Дано :is(-ua-invalid, артикль, p) правило будет соответствовать артикулу и р .
              • Вычисленная специфичность будет равна специфичности переданного селектора с наивысшей специфичностью. Например, :is(#id, p) будет иметь специфичность #id — 1.0.0 — тогда как :is(p, a) будет иметь специфичность 0.0.1.

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

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

               :is(h2, h3, h4) {
                высота строки: 1,2;
              }
              : is (h3, h4): не (: первый ребенок) {
                поле сверху: 2em;
              }
               

              В этом примере (который исходит из стилей документа в моем проекте SmolCSS), имея большее line-height , унаследованная от базовых стилей или отсутствие margin-top , на самом деле не является проблемой для не поддерживающих браузеров. Это просто далеко от идеала. Чего вы не хотели бы использовать :is() , так это важных стилей макета , таких как Grid или Flex, которые значительно контролируют ваш интерфейс.

              Кроме того, при привязке к другому селектору вы можете проверить, соответствует ли базовый селектор селектору-потомку в пределах :is() . Например, следующее правило выбирает только те абзацы, которые являются прямыми потомками статей. Универсальный селектор используется как ссылка на p селектор базы.

               p:is(статья > *)
               

              Для наилучшей текущей поддержки, если вы хотите начать использовать ее, вы также захотите удвоить стили , включив повторяющиеся правила, используя :-webkit-any() и :matches() . Не забудьте сделать эти индивидуальные правила, иначе даже поддерживающий браузер их выбросит! Другими словами, включите все следующее:

               :matches(h2, h3, h4) { }
              :-webkit-любой (h2, h3, h4) { }
              : есть (h2, h3, h4) { }
               

              На этом этапе стоит упомянуть, что наряду с самими новыми селекторами есть обновленная версия @supports , которая представляет собой @supports selector . Это также доступно как @supports not selector .

              Примечание : В настоящее время (из современных браузеров) только Safari не поддерживает это правило at.

              Вы можете проверить наличие поддержки :is() с помощью чего-то вроде следующего, но на самом деле вы потеряете поддержку Safari, поскольку Safari поддерживает :is() , но не поддерживает @supports selector .

               @supports selector(:is(h2)) {
                : есть (h2, h3, h4) {
                  высота строки: 1,1;
                }
              }
               

              :where()

              Псевдокласс :where() почти идентичен :is() , за исключением одного важного отличия: всегда будет иметь нулевую специфичность. Это имеет невероятные последствия для людей, которые создают фреймворки, темы и дизайн-системы . Использование :where() , автор может установить значения по умолчанию, а последующие разработчики могут включать переопределения или расширения без конфликта специфики.

              Рассмотрим следующий набор стилей img . Используя :where() , даже с селектором более высокой специфичности специфичность остается нулевой. Как вы думаете, в следующем примере граница какого цвета будет у изображения?

               : где (статья img: не (: первый ребенок)) {
                  граница: 5 пикселей сплошного красного цвета;
              }
              :где(статья) img {
                граница: 5px сплошной зеленый цвет;
              }
              картинка {
                граница: 5 пикселей сплошного оранжевого цвета;
              }
               

              Первое правило имеет нулевую специфичность, поскольку полностью содержится в :where() . Таким образом, непосредственно против второго правила выигрывает второе правило. Представляя селектор только элемента img в качестве последнего правила, он выиграет благодаря каскаду. Это связано с тем, что оно будет вычисляться с той же специфичностью, что и правило :where(article) img , поскольку часть :where() не увеличивает специфичность.

              Использование :where() вместе с резервными вариантами немного сложнее из-за функции нулевой специфичности, так как именно из-за этой функции вы, вероятно, хочет, чтобы использовал его вместо :is() . И если вы добавите резервные правила, они, скорее всего, превзойдут :where() из-за самой их природы. И общая поддержка у него на лучше, чем у селектора @supports , поэтому попытка использовать его для создания отката вряд ли принесет большую выгоду (если вообще даст). По сути, помните о невозможности правильно создать резервные копии для :where() и тщательно проверьте свои собственные данные, чтобы определить, безопасно ли начинать использовать для вашей уникальной аудитории.

              Вы можете дополнительно протестировать :where() с помощью следующего CodePen, который использует селекторы img из приведенного выше: smashingmag/pen/jOyXVMg) Стефани Эклз.

              См. Pen Testing :where() специфичность Стефани Эклз.

              Расширенный

              :not()

              Базовый селектор :not() поддерживается начиная с Internet Explorer 9. Но селекторы уровня 4 улучшают :not() , позволяя ему принимать список селекторов, точно так же, как :is() и :where() .

              Следующие правила дают тот же результат в поддерживаемых браузерах:

               article :not(h3):not(h4):not(h5) {
                нижняя граница: 1.5em;
              }
              статья: не (h3, h4, h5) {
                нижняя граница: 1.5em;
              }
               

              Способность :not() принимать список селекторов отлично поддерживается современными браузерами.

              Как мы видели с :is() , расширенный :not() также может содержать ссылку на базовый селектор как на потомка с использованием * . Этот CodePen демонстрирует эту способность, выбирая ссылки, которые являются , а не потомками nav .

              См. Pen [Тестирование :not() с помощью селектора потомков](https://codepen.io/smashingmag/pen/BapvQQv) Стефани Эклс.

              См. Pen Testing :not() с селектором потомков Стефани Эклз.

              Бонус : предыдущая демонстрация также включает пример объединения :not() и :is() для выбора изображений, которые не являются соседними элементами h3 или h4 .

              Предлагается, но «под угрозой» —

              :has()

              Последний псевдокласс, который является очень захватывающим предложением, но не имеет текущего браузера, реализующего его даже экспериментально, — это :has() . На самом деле, он указан в редакционном черновике Selector Level 4 как «находящийся под угрозой», что означает, что он испытывает трудности с завершением его реализации, и поэтому он может исключить из рекомендации.

              В случае реализации :has() , по сути, это был бы «родительский селектор», о котором мечтали многие специалисты по CSS. Это будет работать с логикой, аналогичной комбинации :focus-within и :is() с селекторами потомков, где вы ищете наличие потомков , но применяемый стиль будет применяться к родительскому элементу.

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

               навигация {
                набивка: 0,75 бэр 0,25 бэр;
              навигация: имеет (кнопка) {
                набивка-верх: 0,25 бэр;
                прокладка-дно: 0,25 бэр;
              }
               

              Опять же, это , а не , который в настоящее время реализован в любом браузере даже экспериментально — но об этом интересно подумать! Робин Рендл предоставил дополнительную информацию об этом будущем селекторе на CSS-Tricks.

              Почетное упоминание с уровня 3:

              :пусто

              Полезный псевдокласс, который вы, возможно, пропустили на уровне селекторов 3: :пусто , который соответствует элементу, если у него нет дочерних элементов, включая текстовые узлы.

              Правило p:пусто будет соответствовать

              , но не

              Hello

              .

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

               .search-results:empty {
                дисплей: нет;
              }
               

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