Сайт о телевидении

Сайт о телевидении

» » Самые часто используемые селекторы в css. Дефис в значении атрибута. Атрибут со значением

Самые часто используемые селекторы в css. Дефис в значении атрибута. Атрибут со значением

Parent()
Возвращает родительские элементы всех элементов первоначального обернутого набора, расположенные на один уровень выше.
Параметры
селектор

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

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

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

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

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

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

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

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

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

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

Is()
Проверяет обернутый набор на наличие, по крайней мере, одного элемента, соответствующего заданному селектору. Возвращает true , если заданному селектору соответствует хотя бы один элемент, в противном случае false .
Параметры
селектор

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

Size()
Возвращает количество элементов в обернутом наборе.
Параметры
нет

Get()
Возвращает один элемент в соответствии с заданным индексом или массив элементов, если параметр не указан. Отрицательный индекс ведет отсчет с конца обернутого набора элементов.
Параметры
число, задающее индекс возвращаемого элемента

ToArray()
Возвращает массив элементов, содержащихся в обернутом наборе.
Параметры
нет

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

Add()
Возвращает новый набор, содержащий копию элементов первоначального набора, в который добавлены элементы, определенные параметром.
Параметры
элемент, селектор, массив элементов, фрагмент html-разметки

Each()
Позволяет перебрать все элементы выборки страницы и произвести серию действий над каждым из них. Вызываемой функции передаются два параметра — индекс элемента набора и сам элемент, который устанавливается в качестве контекста функции this .
Параметры
функция

Map()
Вызывает функцию для каждого элемента в обернутом наборе и возвращает полученные значения в виде массива JavaScript. Функции передаются два параметра — индекс элемента внутри набора и сам элемент.
Параметры
функция

End()
Используется внутри цепочки методов jQuery, возвращает предыдущий обернутый набор, чтобы применить к нему последующие операции.
Параметры
нет

AndSelf()
Объединяет два самых верхних обернутых набора в единый набор.
Параметры
нет

2. Фильтрующие методы

First()
Возвращает из обернутого элемента только первый элемент.
Параметры
нет

Eq()
Возвращает из обернутого набора только один элемент. Отрицательное значение индекса ведет отсчет с конца набора.
Параметры
число, соответствующее индексу возвращаемого элемента

Last()
Возвращает из обернутого элемента только последний элемент.
Параметры
нет

Slice()
Возвращает набор элементов, содержащий элемент с начальным индексом и элементы до конечного индекса. Если конечный индекс отсутствует, то элементы от начального и до конца набора. Отрицательный индекс ведет отсчет элементов с конца набора, -1 вернет последний элемент.
Параметры
начальный индекс, конечный индекс (не обязательно)

Filter()
Удаляет из обернутого набора элементы, не соответствующие правилу отбора. Возвращает копию первоначального обернутого набора, из которого удалены указанные элементы. Если параметром является функция, она будет вызвана для каждого элемента в наборе, чтобы проверить, соответствует ли элемент заданному критерию отбора. Если для элемента будет возвращено значение false , то он будет удален из набора.
Параметры

Not()
Удаляет из выбранного множества все элементы, соответствующие заданному выражению селектора. Возвращает копию первоначального обернутого набора, из которого удалены указанные элементы. Если параметром является функция, она будет вызвана для каждого элемента в наборе, чтобы проверить, соответствует ли элемент заданному критерию отбора. Если для элемента будет возвращено значение false , то он будет удален из набора.
Параметры
элемент, селектор, массив или функция

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

Всем привет, хабрчане.
Сегодня CSS окружает нас вокруг, и даже маломайский программист должен понимать его.
Самыми используемыми являются старые добрые #id и.class они знакомы всем, кто хоть раз работа с CSS.
На этом конечно мир Селекторов далеко не ограничивается. Я уже довольно давно работаю с CSS и хочу поделится как можно большим количеством полезных селекторов. Все они определяют стиль того или иного объекта.

CSS Selectors

Объясняю многие селекторы применимо к указанному примеру.

.class
(Пр. .main) Данный селектор объединяет все элементы с классом «main». Родился он давно и активно учувствует в разработке.
#id
(Пр. #Block_Form) Этот селектор объедение элементы с id=«Block_Form» В чем скажите разница между.class и #id - а разницу можно понять на примере: то что ПАСПОРТНЫЙ НОМЕР = id, ФАМИЛИЯ = class. Также немало важно то, что - Идентификатор (id) можно вызвать из скрипта используя функцию GetElementById, в отличие от класса.
Класс может быть использован многократно, идентификатор же должен быть уникальным.
*
Выбирает, объединяет все элементы
(Пр. *) { background-color:yellow; })
element
(Пр. p) Объединяет все элементы тега p.
element,element
(Пр. div,p) Объединяет все элементы div и все элементы p
.
Так же в эту группу можно выделить похожие селекторы:
element element
(Пр. div p) Выбирает все элементы p внутри div.
element>element
(Пр. div>p) Объединяет все p для которых родителем выступает div.
element+element
(Пр. div+p) Объединяет все p которые расположены сразу после div.
(Пр. ) Объединяет все элементы с атрибутом target
(Пр. ) Объединяет все элементы с заданным target="_blank"
(Пр. ) Объединяет все элементы, которые в своем title содержат «Apple»
(Пр. ) Объединяет все элементы с атрибутом class начиння с «top»

Все теги написаны были без "<>".

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

Так же их называют Псевдокласы:
:link
(Пр. a:link) Объединяет все ссылки, которые еще не посещались (Пр. a:visited) Объединяет все ссылки, которые пользователь уже успел посетить
:active
(Пр. a:active) Псевдокласс:active определяет стиль для активной ссылки. Активной ссылка становится при нажатии на нее.
:hover
(Пр. a:hover) Когда проводишь мышкой, ссылка может менять стиль
:focus
(Пр. input:focus) Изменяет стиль при фокусировке. на практике часто используется для подсветки полей формы при фокусировке на нем
:first-letter
(Пр. p:first-letter) Определяет стиль для первого символа в тексте элемента
:first-line
(Пр. p:first-line) Определяет стиль первой строки. Использую для изменения цвета текста, цвета фона и шрифта, но как показывают народные хабрумельцы на этом его функции не ограничиваются
:first-child
(Пр. p:first-child) Что бы просто объяснить - применяет стилевое оформление к первому дочернему элементу своего родителя. В примере если р есть первым элементом своего родителя
Дальше идут два очень интересных класса:
:before
(Пр. p:before)
:after
(Пр. p:after)
Они применяются в тех случаях, когда - нужно отобразить нужный контент до или после содержимого элемента, к которому он добавляется. Работает совместно со свойством content:. Так же я их использую как дополнительные элементы вместо div, в таком случае нужно прописывать content:"";. Также нужно помнить о том, что при добавлении:before к блочному элементу, значение свойства display может быть только: block, inline, none, list-item. Все остальные значения будут трактоваться как block. При добавлении:before к встроенному элементу, display ограничен значениями inline и none. Все остальные будут восприниматься как inline.
:before наследует стиль от элемента, к которому он добавляется.
:lang(language)
(Пр. p:lang(it)) Довольно простой, но порой нужный элемент - для примера: Определяет стиль каждого p с атрибутом lang, значение которого начинается с «it»
Селекторы CSS3

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

element1~element2
(Пр. p~ul)
p~ul { background:red; } Устанавливает цвет фона для всех ul элементов, которые предшествуют p с таким же родителем. Грубо говоря - на этом примере, красным будет бэкграунд только у тех «списков» которые стоят после родителя тега р.
A div element.
  • Item
  • Item
  • Item
- в этом случае ничего не произойдет, а в
  • Item
  • Item
  • Item

а в этом случае поля Айтемов будут иметь бэк-цвет - красный.
(Пр. a) По примеру определяет стиль каждого a для которого значение элемента src начинающегося с «https». Вот еще пример:
item1
item2
item3

Item4


Проще говоря – данный селектор дает возможность установить цвет фона на всех div элементов, которые имеют значение атрибута класса, начинающихся с «тест» – а именно item3, item4.
(Пр. a) Выбирает каждый тег a, для которого SRC значение атрибута заканчивается на ". PDF. И вот еще один наглядный пример:
Item1
Item2
Item3

Item4


На этом примере очень хорошо будет видно использование данного селектора, а именно в Красный цвет перекрасятся Item1 (по тому что класс заканчивается на _test) и item3.
(Пр. a) Выбирает каждый тег a, для которого значение атрибута SRC содержит подстроку «w3schools».
item1
item2
item3

Item4


В этом примере результатом будут закрашенные строки item1, item3, item4.
:first-of-type
(Пр. p:first-of-type) Задает правила стилей для первого элемента в списке дочерних элементов своего родителя.
:last-of-type
(Пр. p:last-of-type) Соответственно задает правила стилей для последнего элемента в списке дочерних элементов своего родителя.
:only-of-type
(Пр. p:only-of-type) А вот этот применяется к дочернему элементу указанного типа, только если он единственный у родителя. Аналогично как:first-of-type:last-of-type или:nth-of-type(1):nth-last-of-type(1).
:only-child
(Пр. p:only-child) Такой элемент применяется по примеру к дочернему элементу p, только если он единственный у родителя

Следующие два можно также неплохо использовать для определенной последовательности – нечетные (odd), четные(even) или число(1,2,3… или выражения 2n+1), заданные в (Х):

:nth-child(n)
(Пр. p:nth-child(2)) Для каждого

Который является вторым дочерним элементом у родителя.

:nth-last-child(n)
(Пр. p:nth-last-child(2)) Тот же смысл, что и у предыдущего, кроме того, что отсчет ведется не от первого элемента, а от последнего.
:nth-of-type(n)
(Пр. p:nth-of-type(2)) Используется для добавления стиля к элементам указанного типа на основе нумерации. Например, для картинок у заглавия применить со значением Float: -left or –right.
:nth-last-of-type(n)
(Пр. p:nth-last-of-type(2)) Тоже, что и предыдущий, но отсчет ведется не от первого элемента, а от последнего.
:last-child
(Пр. p:last-child) Данный селектор задает стилевое оформление последнего элемента своего родителя.

Также стоит выделить:

:root
(Пр. :root) Такой селектор определяет корневой элемент документа, иначе говоря - .
:empty
(Пр. p:empty) Определяет пустые элементы - без каких-либо дочерних элементов, текста или пробелов.
:target
(Пр.#news:target) Грубо говоря – это определение на основе целевого элемента. В примере определение текущего id - #news element. Используется для URL.
:enabled
(Пр. input:enabled) Применяется к формам, как доступ к доступным (не заблокированным - disabled) элементам форм, простите за тавтологию.
:disabled
(Пр. input:disabled) Иначе говоря – применимо к стилю заблокированных элементов формы.
:checked
(Пр. input:checked) Данный псевдокласс применим к элементам интерфейса, таким как переключатели (checkbox) и флаги (radio), когда они включены, конечно же.
:not(selector)
(Пр. :not(p)) На примере стиль применяется ко всем элементам, которые не p. В качестве селектора могут быть псевдоклассы, теги, идентификаторы, классы и селекторы атрибутов.

Последнее обновление: 21.04.2016

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

Например, пусть элемент body на веб-странице имеет следующее содержимое:

Заголовок

Внутри элемента body определено три вложенных элемента: h2, div, p. Все эти элемены являются потомками элемента body.

А внутри элемента div определен только один вложенный элемент - p, поэтому элемент div имеет только одного потомка.

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

Селекторы CSS

Первый абзац

Второй абзац

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

#main p{ font-size: 16px; }

То есть данный стиль будет применяться только к тем элементам p, которые находятся внутри элемента с идентификатором main.

Рассмотрим другой пример:

Селекторы CSS

Здесь стиль применяется к элементам с классом "redLink", которые находятся внутри элемента

  • . И соответственно браузер окрасит эти элементы в красный цвет:

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

  • Но если мы уберем пробел:

    Li.redLink{ color: red; }

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

  • , которые имеют класс redLink . Например, к следующему элементу:

  • Но никак не к элементу:

  • LG: LG G5
  • ". Итак, селектор - это элемент, к которому применяется объявление в правиле стиля.

    Термины, используемые в описании правил CSS.

    Рис.1. Обычное правило CSS. Рис.2. Пример правила CSS.

    Коротко про синтаксис записи правил CSS:

    • Объявление стиля в парвиле берётся в фигурные скобки - {}
    • Свойство и значение в объявлении разделяются двоеточием - :
    • В одном объявлении (в одной паре фигурных скобок) может быть указано сколько угодно пар свойство: значение
    • В конце каждой пары свойство: значение ставится точка с запятой - ;
    • После последней пары свойство: значение точку с запятой ставить не обязательно.
    • Синтаксис CSS не чувствителен пробельным символам (пробелы, табуляция, переносы сток).
    • Синтаксис CSS не чувствителен к регистру символов.

    В качесте селекторов может выступать любой тег HTML, также есть селекторы класса либо id-селекторы. Рассмотрим всё по порядку.

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

    Как писалось ранее, любой тег может быть селектором в правиле CSS. Рассмотрим пример.

    Синтаксис CSS

    Привет!

    Заголовок h2!

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

    ,

    и

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

    Группирование в CSS

    Привет h1!

    Заголовок h2!

    Такая запись стиля равносильна следующей группе правил:

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

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

    Внутри таблицы

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

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

    Привет!

    Текст абзаца в таблице.

    Текст абзаца вне таблицы.

    Все теги

    Во всех таблицах документа будут отображать цвет красным цветом. Обратите внимание, то тег

    Находящийся внутри тега

    тоже отображает текст красным цветом.

    На самом деле, вместо

    можно было указать тег
    , так как тег всегда должен содержать тег
    .

    Для дальнейшего изучения селекторов CSS нужно освоить несколько несложных терминов относящихся к структуре документа.

    Дерево документа (англ. document tree) - это схема построения HTML документа, показывающая порядок следования тегов и их вложенность друг в друга. Приведём пример такой схемы:


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

    Вот пример кода, соответствующего схеме дерева элементов с рисунка 1.

    Дерево документа.

    Привет!

    Текст абзаца и жирный.

      • Пункт 1.1
      • Пункт 1.2
      • Пункт 1.3
      1. Пункт 2.1
      2. Пункт 2.2
      3. Пункт 2.3

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

    Теперь рассмотрим все типы связей.

    Предки и потомки

    Предки (ancestor) - элементы, которые содержат другие элементы, то есть элемент является предком для всех вложенных в него элементов.

    Потомки (descendant) - элементы, вложенные в другой элемент.

    Селекторы потомков уже были рассмотрены выше.

    Родители и дочерние элементы

    Родитель (parent) - это предок первого уровня (непосредственный предок) для элемента. Дочерний элемент (child - ребёнок) - это потомок первого уровня. Родительский элемент может иметь неограниченное число детей.

    В нашем дереве элементов у тега следующие дочерние элементы:

    ,

    ,

      и ещё один

      Братские или сестринские элементы

      Братские или сестринские элементы, (англ. siblings - братья и сестры), группа элементов имеющая общего родителя. Например, теги

      ,

      ,

        и второй

        Сестринские, так как у них общий родитель .

        Смежные элементы

        Смежные элементы - это соседние братские элементы, то есть элементы имеющие общего родителя и идущие радом в дереве элементов. В нашем примере смежными элементами будут пары:

        и

        ,

        И

          ,
            и

            Теперь вернёмся к селекторам.

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

            Когда нас интересуют не все потомки, а только потомки первого уровня, то есть дочерние элементы, в CSS используют дочерние селекторы. Для указания того, что правило стиля задано только к дочернему элементу, в селекторе используется символ ">".

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

            Привет!

            Текст абзаца в таблице.

            Текст абзаца в таблице (в контейнере div).

            Текст абзаца вне таблицы.

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

            уже не красного цвета, так как для этого абзаца тег
            родитель, а тег

    предок.

    Смежный (соседний) селектор

    Селектор смежного элемента выбирает элемент, расположенный непосредственно за другим заданным элементом. Синтаксис этого селектора: селектор предыдущего элемента, знак "+" и за ним селектор выбираемого элемента.

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

    , желательно увеличить верхний отступ (свойство margin-top ). Отступ в 20px будет придавать тексту читабельности. Но вот в случае, если тег

    идёт сразу после

    , а это может быть в начале статьи, вержний отступ над тегом

    будет лишним. Решить такую задачу можно при помощи селектора смежного элемента.

    Вот html-код с примером работы селектора смежного элемента.

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

    Привет!

    Заголовок h2

    Заголовок h2

    Текст абзаца в про невероятные приключения.

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

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

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

    Пример исользования сестринского селектора.

    Селектор родственного элемента в CSS

    Привет!

    Текст абзаца №1 в про невероятные приключения.

    Текст абзаца №2 в про невероятные приключения.

    Текст div №1 в про невероятные приключения.

    Текст абзаца №3 в про невероятные приключения.

    Из примера видно, что после

    тега текст абзаца №3 также был красным цветом. То есть, для присвоения стиля сестринские элементы не должны идти друг за другом.

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

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

    * { margin: 0; padding: 0; }

    Но символ "*" можно использовать в составных селекторах.

    Ul * {color: red}

    Этот код назначает красный цвет тексту всех потомков элемента

      .

      Классы

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

      Тег.Имя класса

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

      Пример, когда применяют классы: на сайте верхнее, боковое и нижнее меню создаётся при помощи тегов

        , этим трём меню нужно создать три различных стиля. В CSS создают три класса ul.menu-top , ul.menu и ul.menu-bottom .

        В теле html-документа различные меню создаются с указанием класса в атрибуте class :

          class ="menu-top "> ...

          class ="menu "> ...

          class ="menu-bottom "> ...

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

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

        *.Имя класса { свойство1 : значение ; свойство2 : значение ; ... }

        Эту запись можно сократить, убрав символ "*".

        Имя класса { свойство1 : значение ; свойство2 : значение ; ... }

        ID селекторы (идентификаторы)

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

        При описании идентификатора вначале указывается символ решётки (#), затем идет имя идентификатора.

        #Имя идентификатора { свойство1 : значение ; свойство2 : значение ; ... }

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

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

        В HTML есть ряд тегов, которые в зависимости от атрибутов меняют своё действие. Например, тег зависимости от значения атрибута type может создавать поле формы, кнопку и другие элементы формы. Так что, если применять стиль к селектору input , то он изменит все элементы формы, созданные этим тегом. Для точного управления такими элементами в CSS существуют селекторы атрибутов.

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

        Селекторы атрибутов - тема отдельной большой статьи. В рамках этой статьи мы лишь отметим, что они есть.

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

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

        При помощи псевдоклассов создаются динамические эффекты на странице.

        Синтаксис псевдокласса:

        Селектор:псевдокласс { свойство1 : значение ; свойство2 : значение ; ... }

        Можно применять псевдоклассы к селекторам идентификаторов или классов (ul.menu:hover {color : green }).

        Для новичков отмечу: если именам классов и идентификатов разработчик придумывает названия сам, то имена псевдоклассов в CSS - это зарезервированные слова.

        Псевдокласс :active выполняет правило стиля, если элемент активен. Например, на ссылку наведён курсор и произведён клик. Псевдокласс :hover - курсор мыши просто наведён на элемент, например на ссылку.

        Есть ещё много псевдоклассов. Полностью раскрыть тему псевдоклассов можно в рамках отдельной статьи. Тут мы коснулись её лишь поверхностно.

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

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

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

        Синтаксис псевдоэлементов такой же, как и у псевдоклассов:

        Селектор:псевдоэлемент { свойство1 : значение ; свойство2 : значение ; ... }