Псевдоклассы форм

Псевдоклассы форм

Coursme
8 мин.
31 янв. 2024

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

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

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

:enabled и :disabled:

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

:enabled {
   border: 2px solid black;
   color: blue;
}

Пример:

<input type="text" value="Enabled" />
<input type="text" disabled value="Disabled" />

Этот код демонстрирует стилизацию активного и неактивного текстового поля. Первое поле доступно для взаимодействия, а второе неактивно и выделено серым цветом.

:checked:

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

:checked + span {
   color: green;
   font-weight: bold;
}

Пример:

<input type="checkbox" checked name="Best"/><label for="html5">Coursme</label>
<input type="checkbox" name="Kall"/><label for="dotnet">Coursera</label>

Здесь :checked применяет стили к соседнему элементу <label>, если соответствующий чекбокс отмечен. Это может быть использовано для визуального подтверждения выбранных опций.

:default:

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

:default {
   border: 2px solid red;
}

Пример:

<form>
   <input name="login"/>
   <input type="submit" value="Login" />
</form>

Этот код выделяет кнопку отправки формы с помощью :default. Это подчеркивает действие, которое произойдет по умолчанию при отправке формы.

:valid и :invalid:

Эти псевдоклассы помогают стилизовать элементы формы в зависимости от их валидности. :valid применяет стили к правильно заполненным элементам, тогда как :invalid — к неверно заполненным. Очень полезно для обозначения правильности вводимых данных.

input:valid {
   border: 2px solid green;
}
input:invalid {
   border: 2px solid red;
}

Пример:

<form>
   <input type="email" name="email" placeholder="Напишите свой email" required />
   <input type="submit" value="Отправить" />
</form>

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

:in-range и :out-of-range:

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

:in-range {
   border: 2px solid green;
}
:out-of-range {
   border: 2px solid red;
}

Пример:

<form>
   <label for="age">Ваш возраст:</label> 
   <input type="number" min="1" max="100" value="18" id="age" name="age"/>
   <input type="submit" value="Отправить" />
</form>

Псевдоклассы :in-range и :out-of-range в этом коде подсвечивают поле ввода возраста зеленым, если значение в пределах 1-100, и красным в противном случае.

:required и :optional:

Эти псевдоклассы стилизуют элементы формы в зависимости от наличия атрибута required. :required применяет стили к обязательным для заполнения элементам, в то время как :optional — к необязательным. Это может быть полезно для выделения важных полей.

:required {
   border: 2px solid red;
}
:optional {
   border: 2px solid blue;
}

Пример:

<!DOCTYPE html>
<html lang="ru">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <style>
        form {
            max-width: 300px;
            margin: 0 auto;
        }

        label {
            display: block;
            margin-bottom: 8px;
        }

        input {
            width: 100%;
            padding: 8px;
            margin-bottom: 16px;
            box-sizing: border-box;
            border: 2px solid #ccc;
            border-radius: 4px;
        }

        input:required {
            border-color: red;
        }

        input:optional {
            border-color: blue;
        }

        input[type="submit"] {
            background-color: #4CAF50;
            color: white;
            cursor: pointer;
            border: none;
            border-radius: 4px;
            padding: 10px 20px;
        }

        input[type="submit"]:hover {
            background-color: #45a049;
        }
    </style>
    <title>Оформление Формы</title>
</head>
<body>
    <form>
        <label for="username">Имя пользователя:</label> 
        <input type="text" id="username" name="username" required />

        <label for="password">Пароль:</label> 
        <input type="password" id="password" name="password" required />

        <label for="optionalField">Дополнительное поле:</label>
        <input type="text" id="optionalField" name="optionalField" />

        <input type="submit" value="Отправить" />
    </form>
</body>
</html>

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

Заключение

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

Назад
Следующий тест
Комментарии
Чтобы оставлять комментарии — надо авторизоваться
Комментариев еще нет
Будьте первым
Главная
Кабинет
Курсы
Меню