Псевдокласс :focus-visible используется для применения стилей к элементу, который получил фокус, но когда переход к элементу происходит с помощью клавиатуры. Это позволяет избежать появления браузерных стилей в случае, если пользователь их не ожидает.
По своему действию похож на псевдокласс :focus, но есть некоторые отличия.
:focus работает для получивших фокус элементов без каких-либо оговорок и условий. Это значит, что не имеет значения, каким образом элемент получил фокус — :focus сработает всегда.
:focus-visible работает при определённых условиях — браузер определяет, как элемент получил фокус и в зависимости от этого применяет стили или нет. К примеру, при использовании мыши текстовые поля стилизуются, а кнопки нет. При получении фокуса с помощью клавиатуры стилизуется и кнопка.
Синтаксис
Селектор:focus-visible { … }
Синтаксис
Описание
Пример
<тип>
Указывает тип значения.
<размер>
A && B
Значения должны выводиться в указанном порядке.
<размер> && <цвет>
A | B
Указывает, что надо выбрать только одно значение из предложенных (A или B).
normal | small-caps
A || B
Каждое значение может использоваться самостоятельно или совместно с другими в произвольном порядке.
width || count
[ ]
Группирует значения.
[ crop || cross ]
*
Повторять ноль или больше раз.
[,<время>]*
+
Повторять один или больше раз.
<число>+
?
Указанный тип, слово или группа не является обязательным.
В данном примере если щёлкнуть по кнопке из первой группы, то вокруг кнопки отображается оранжевый контур. Кнопки из второй группы при щелчке контуром не выделяются. При переходе к кнопке с помощью клавиши Tab, кнопка выделяется контуром соответствующего цвета.
Каждая спецификация проходит несколько стадий одобрения.
Recommendation (Рекомендация) — спецификация одобрена W3C и рекомендована как стандарт.
Candidate Recommendation (Возможная рекомендация) — группа, отвечающая за стандарт, удовлетворена, как он соответствует своим целям, но требуется помощь сообщества разработчиков по реализации стандарта.
Proposed Recommendation (Предлагаемая рекомендация) — на этом этапе документ представлен на рассмотрение Консультативного совета W3C для окончательного утверждения.
Working Draft (Рабочий проект) — более зрелая версия черновика после обсуждения и внесения поправок для рассмотрения сообществом.
Editor's draft (Редакторский черновик) — черновая версия стандарта после внесения правок редакторами проекта.
Draft (Черновик спецификации) — первая черновая версия стандарта.
Браузеры
86
86
72
15.4
85
86
85
61
15.4
Браузеры
В таблице браузеров применяются следующие обозначения.
— элемент полностью поддерживается браузером;
— элемент браузером не воспринимается и игнорируется;
— при работе возможно появление различных ошибок, либо элемент поддерживается с оговорками.
Число указывает версию браузреа, начиная с которой элемент поддерживается.