Кратко
Скопировано:user и :user — псевдоклассы, которые совпадают с элементами форм по их валидности, но только после того, как пользователь изменил значение поля (элемент стал "грязным"). Это позволяет показывать обратную связь не сразу при загрузке страницы, а лишь после действия пользователя.
:valid/:invalidсрабатывают всегда по текущему состоянию поля, даже до взаимодействия.- Пока пользователь не взаимодействовал с полем, ни
:user, ни- valid :userне совпадают с элементом, даже если он уже не проходит HTML-валидацию.- invalid
Пример
СкопированоНиже поля покажут "успех/ошибку" только после того, как вы что‑то введёте и уберёте фокус с поля.
Как пишется
Скопировано
/* Ошибка показывается только после пользовательского ввода */input:user-invalid { border-color: #F498AD;}/* Успех — тоже только после ввода */input:user-valid { border-color: #41E847;}
/* Ошибка показывается только после пользовательского ввода */
input:user-invalid {
border-color: #F498AD;
}
/* Успех — тоже только после ввода */
input:user-valid {
border-color: #41E847;
}
Как понять
СкопированоЭти псевдоклассы зависят от факта взаимодействия пользователя с полем. До первого изменения значения состояние валидности игнорируется. Это делает формы менее "агрессивными": подсветка ошибок и успеха появляется после действия человека.
Подсказки
Скопировано💡 Используйте :user вместо мгновенного :invalid, когда хотите убрать "красные рамки" на свежезагруженной странице.
💡 Комбинируйте с :focus/:focus: фокус — синий обводкой, валидность — своим цветом после ввода.
💡 Добавляйте текстовые подсказки соседним элементом и показывайте их через соседние селекторы: input.
💡 Для кросс‑браузерности можно продублировать стили на :invalid как "запасной вариант", если это уместно по UX.