Переключатели

Стилизация Radio Button

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

Стандартные элементы

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

 
.form_radio < margin-bottom: 10px; >.form_radio input[type=radio] < display: none; >.form_radio label < display: inline-block; cursor: pointer; position: relative; padding-left: 25px; margin-right: 0; line-height: 18px; user-select: none; >.form_radio label:before < content: ""; display: inline-block; width: 17px; height: 18px; position: absolute; left: 0; bottom: 1px; background: url(/img/radio-1.png) 0 0 no-repeat; >/* Checked */ .form_radio input[type=radio]:checked + label:before < background: url(/img/radio-2.png) 0 0 no-repeat; >/* Hover */ .form_radio label:hover:before < filter: brightness(120%); >/* Disabled */ .form_radio input[type=radio]:disabled + label:before

Radio в виде кнопок

 
.form_radio_btn < display: inline-block; margin-right: 10px; >.form_radio_btn input[type=radio] < display: none; >.form_radio_btn label < display: inline-block; cursor: pointer; padding: 0px 15px; line-height: 34px; border: 1px solid #999; border-radius: 6px; user-select: none; >/* Checked */ .form_radio_btn input[type=radio]:checked + label < background: #ffe0a6; >/* Hover */ .form_radio_btn label:hover < color: #666; >/* Disabled */ .form_radio_btn input[type=radio]:disabled + label

Группа кнопок

 
.form_radio_group < display: inline-block; overflow: hidden; >.form_radio_group-item < display: inline-block; float: left; >.form_radio_group input[type=radio] < display: none; >.form_radio_group label < display: inline-block; cursor: pointer; padding: 0px 15px; line-height: 34px; border: 1px solid #999; border-right: none; user-select: none; >.form_radio_group .form_radio_group-item:first-child label < border-radius: 6px 0 0 6px; >.form_radio_group .form_radio_group-item:last-child label < border-radius: 0 6px 6px 0; border-right: 1px solid #999; >/* Checked */ .form_radio_group input[type=radio]:checked + label < background: #ffe0a6; >/* Hover */ .form_radio_group label:hover < color: #666; >/* Disabled */ .form_radio_group input[type=radio]:disabled + label

Переключатель

.form_toggle < display: inline-block; overflow: hidden; >.form_toggle-item < float: left; display: inline-block; >.form_toggle-item input[type=radio] < display: none; >.form_toggle-item label < display: inline-block; padding: 0px 15px; line-height: 34px; border: 1px solid #999; border-right: none; cursor: pointer; user-select: none; >.form_toggle .item-1 label < border-radius: 6px 0 0 6px; >.form_toggle .item-2 label < border-radius: 0 6px 6px 0; border-right: 1px solid #999; >/* Checked */ .form_toggle .item-1 input[type=radio]:checked + label < background: #ffc5c5; >.form_toggle .item-2 input[type=radio]:checked + label

Источник

Читайте также:  Switch images in html

Переключатели

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

Атрибуты переключателей перечислены в табл. 1.

Табл. 1. Атрибуты переключателей
Атрибут Описание
checked Предварительное выделение переключателя. По определению, набор переключателей может иметь только один выделенный пункт, поэтому добавление checked сразу к нескольким полям не даст особого результата. В любом случае, будет отмечен элемент, находящийся в коде HTML последним.
name Имя группы переключателей для идентификации поля. Поскольку переключатели являются групповыми элементами, то имя у всех элементов группы должно быть одинаковым.
value Задаёт, какое значение будет отправлено на сервер. Здесь уже каждый элемент должен иметь свое уникальное значение, чтобы можно было идентифицировать, какой пункт был выбран пользователем.

Создание группы переключателей показано в примере 1.

Пример 1. Создание переключателей

       

Какое у вас состояние разума?

Не дзен

Дзен

Полный дзен

В результате получим следующее (рис. 1).

Вид переключателей в браузере

Рис. 1. Вид переключателей в браузере

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

Источник

Input radio html примеры

Only one radio button in a given group can be selected at the same time. Radio buttons are typically rendered as small circles, which are filled or highlighted when selected.

Try it

They are called radio buttons because they look and operate in a similar manner to the push buttons on old-fashioned radios, such as the one shown below.

Shows what radio buttons looked like in the olden days.

Note: Checkboxes are similar to radio buttons, but with an important distinction: radio buttons are designed for selecting one value out of a set, whereas checkboxes let you turn individual values on and off. Where multiple controls exist, radio buttons allow one to be selected out of them all, whereas checkboxes allow multiple values to be selected.

Value

The value attribute is a string containing the radio button’s value. The value is never shown to the user by their user agent. Instead, it’s used to identify which radio button in a group is selected.

Defining a radio group

A radio group is defined by giving each of radio buttons in the group the same name . Once a radio group is established, selecting any radio button in that group automatically deselects any currently-selected radio button in the same group.

You can have as many radio groups on a page as you like, as long as each has its own unique name .

For example, if your form needs to ask the user for their preferred contact method, you might create three radio buttons, each with the name property set to contact but one with the value email , one with the value phone , and one with the value mail . The user never sees the value or the name (unless you expressly add code to display it).

The resulting HTML looks like this:

form> fieldset> legend>Please select your preferred contact method:legend> div> input type="radio" id="contactChoice1" name="contact" value="email" /> label for="contactChoice1">Emaillabel> input type="radio" id="contactChoice2" name="contact" value="phone" /> label for="contactChoice2">Phonelabel> input type="radio" id="contactChoice3" name="contact" value="mail" /> label for="contactChoice3">Maillabel> div> div> button type="submit">Submitbutton> div> fieldset> form> 

Here you see the three radio buttons, each with the name set to contact and each with a unique value that uniquely identifies that individual radio button within the group. They each also have a unique id , which is used by the element’s for attribute to associate the labels with the radio buttons.

You can try out this example here:

Data representation of a radio group

When the above form is submitted with a radio button selected, the form’s data includes an entry in the form contact=value . For example, if the user clicks on the «Phone» radio button then submits the form, the form’s data will include the line contact=phone .

If you omit the value attribute in the HTML, the submitted form data assigns the value on to the group. In this scenario, if the user clicked on the «Phone» option and submitted the form, the resulting form data would be contact=on , which isn’t helpful. So don’t forget to set your value attributes!

Note: If no radio button is selected when the form is submitted, the radio group is not included in the submitted form data at all, since there is no value to report.

It’s fairly uncommon to actually want to allow the form to be submitted without any of the radio buttons in a group selected, so it is usually wise to have one default to the checked state. See Selecting a radio button by default below.

Let’s add a bit of code to our example so we can examine the data generated by this form. The HTML is revised to add a block to output the form data into:

form> fieldset> legend>Please select your preferred contact method:legend> div> input type="radio" id="contactChoice1" name="contact" value="email" /> label for="contactChoice1">Emaillabel> input type="radio" id="contactChoice2" name="contact" value="phone" /> label for="contactChoice2">Phonelabel> input type="radio" id="contactChoice3" name="contact" value="mail" /> label for="contactChoice3">Maillabel> div> div> button type="submit">Submitbutton> div> fieldset> form> pre id="log">pre> 

Then we add some JavaScript to set up an event listener on the submit event, which is sent when the user clicks the «Submit» button:

const form = document.querySelector("form"); const log = document.querySelector("#log"); form.addEventListener( "submit", (event) =>  const data = new FormData(form); let output = ""; for (const entry of data)  output = `$output>$entry[0]>=$entry[1]>\r`; > log.innerText = output; event.preventDefault(); >, false, ); 

Try this example out and see how there’s never more than one result for the contact group.

Additional attributes

In addition to the common attributes shared by all elements, radio inputs support the following attributes.

A Boolean attribute which, if present, indicates that this radio button is the default selected one in the group.

Unlike other browsers, Firefox by default persists the dynamic checked state of an across page loads. Use the autocomplete attribute to control this feature.

Using radio inputs

We already covered the fundamentals of radio buttons above. Let’s now look at the other common radio-button-related features and techniques you may need to know about.

Selecting a radio button by default

To make a radio button selected by default, you include checked attribute, as shown in this revised version of the previous example:

form> fieldset> legend>Please select your preferred contact method:legend> div> input type="radio" id="contactChoice1" name="contact" value="email" checked /> label for="contactChoice1">Emaillabel> input type="radio" id="contactChoice2" name="contact" value="phone" /> label for="contactChoice2">Phonelabel> input type="radio" id="contactChoice3" name="contact" value="mail" /> label for="contactChoice3">Maillabel> div> div> button type="submit">Submitbutton> div> fieldset> form> 

In this case, the first radio button is now selected by default.

Note: If you put the checked attribute on more than one radio button, later instances will override earlier ones; that is, the last checked radio button will be the one that is selected. This is because only one radio button in a group can ever be selected at once, and the user agent automatically deselects others each time a new one is marked as checked.

Providing a bigger hit area for your radio buttons

Beyond accessibility, this is another good reason to properly set up elements on your forms.

Validation

Radio buttons don’t participate in constraint validation; they have no real value to be constrained.

Styling radio inputs

The following example shows a slightly more thorough version of the example we’ve seen throughout the article, with some additional styling, and with better semantics established through use of specialized elements. The HTML looks like this:

form> fieldset> legend>Please select your preferred contact method:legend> div> input type="radio" id="contactChoice1" name="contact" value="email" checked /> label for="contactChoice1">Emaillabel> input type="radio" id="contactChoice2" name="contact" value="phone" /> label for="contactChoice2">Phonelabel> input type="radio" id="contactChoice3" name="contact" value="mail" /> label for="contactChoice3">Maillabel> div> div> button type="submit">Submitbutton> div> fieldset> form> 

The CSS involved in this example is a bit more significant:

html  font-family: sans-serif; > div:first-of-type  display: flex; align-items: flex-start; margin-bottom: 5px; > label  margin-right: 15px; line-height: 32px; > input  appearance: none; border-radius: 50%; width: 16px; height: 16px; border: 2px solid #999; transition: 0.2s all linear; margin-right: 5px; position: relative; top: 4px; > input:checked  border: 6px solid black; > button, legend  color: white; background-color: black; padding: 5px 10px; border-radius: 0; border: 0; font-size: 14px; > button:hover, button:focus  color: #999; > button:active  background-color: white; color: black; outline: 1px solid black; > 

Most notable here is the use of the appearance property (with prefixes needed to support some browsers). By default, radio buttons (and checkboxes) are styled with the operating system’s native styles for those controls. By specifying appearance: none , you can remove the native styling altogether, and create your own styles for them. Here we’ve used a border along with border-radius and a transition to create a nice animating radio selection. Notice also how the :checked pseudo-class is used to specify the styles for the radio button’s appearance when selected.

Note: If you wish to use the appearance property, you should test it very carefully. Although it is supported in most modern browsers, its implementation varies widely. In older browsers, even the keyword none does not have the same effect across different browsers, and some do not support it at all. The differences are smaller in the newest browsers.

Notice that when clicking on a radio button, there’s a nice, smooth fade out/in effect as the two buttons change state. In addition, the style and coloring of the legend and submit button are customized to have strong contrast. This might not be a look you’d want in a real web application, but it definitely shows off the possibilities.

Technical summary

Specifications

Browser compatibility

BCD tables only load in the browser

Источник

Оцените статью