Radio button
Radio button
Introduction
An example of the radio button component.
Interactive example
When to use
Use radio buttons in a radio button group to present a set of selectable options.
Use radio buttons when only one option can be selected from a list.
Use a radio button with a conditional field to display a related additional element when that radio button is selected. The conditional field can be set to static so that it is always visible and becomes enabled once the radio button is selected. If the conditional field is set to dynamic the field is only displayed when the radio button is selected.
When not to use
Don’t use radio buttons on their own, they should always appear as part of a radio button group.
Don’t use radio buttons when the user can select multiple options from the list. Use
data:image/s3,"s3://crabby-images/2f760/2f760464ff88d372e8a1264bbf67f56a6c2fa5d8" alt="A radio button group titled ‘What are your favourite coffees?’ with two out of six radio buttons showing as selected."
data:image/s3,"s3://crabby-images/2038d/2038decdba8ac2f0b675f6773e584d91068fa31d" alt="A checkbox group titled ‘What are your favourite coffees?’ with two out of six checkboxes selected."
Don’t use radio buttons to turn something on or off. Use a
data:image/s3,"s3://crabby-images/138d0/138d092c43b66eeb8c9a3f25feb482f9680da166" alt="A two option radio button group with the label ‘Turn on the coffee machine?’ with options for ‘On’ and ‘Off’."
data:image/s3,"s3://crabby-images/f2421/f2421c739e6d76647ee71ebc456458b707445920" alt="Two switches under the heading 'equipment'. One switch is toggled on whilst the other is off."
Interaction behaviour
In most circumstances, set a default selected option from a radio button group to help people understand that something must be selected, and to expedite the completion of the input using the commonly preferred option.
Alternatively, use a radio button group without a default selected option to force people to select an option before moving on. This eliminates bias towards a single option and avoids people skipping over the question by leaving the default selection.
Sizing
Use small sized radio button groups to achieve compact layouts. Always use small sized components with other small sized components.
Layout and placement
Stack radio buttons when there are more than two options.
data:image/s3,"s3://crabby-images/5023e/5023e7b5b1630767ddff9a37eb51fa7b9c47be3b" alt="A radio button group titled ‘What milk would you like?’ with three radio buttons for ‘dairy’, ‘soya’ and ‘nut’ stacked vertically."
data:image/s3,"s3://crabby-images/d716c/d716c93caf0f4997c3f4e19579fbddf95b493042" alt="A radio button group asking ‘What milk would you like?’ and showing three options for ‘Dairy’, ‘Soya’ and ‘Nut’ displayed in a row."
If there are only two options, you can display them either stacked or in a row.
data:image/s3,"s3://crabby-images/ee9f9/ee9f927ea4da60f7ea5a4387629f9e5e864bf576" alt="A radio button group asking ‘Would you like a coffee?’ with radio buttons for ‘Yes’ and ‘No’ displayed in a row. A second radio button group asking ‘What milk would you like?’ with radio buttons for ‘Dairy’ and ‘Soya’ displayed stacked."
Validation
There are two types of error that can occur on a radio button: a radio button input error or an error on a radio button's conditional field.
A radio button input error is when the radio button group itself is responsible for the error. This is shown using the radio button error state.
data:image/s3,"s3://crabby-images/7f1e8/7f1e8767bde8fc902e86a967af5309d146a1f78e" alt="A radio button group displayed with no radio button selected with an error message reading ‘Please select an option’."
For errors on a radio button’s conditional field, the error is shown only on the conditional field itself and not on the parent radio button group component.
data:image/s3,"s3://crabby-images/f94e4/f94e41eb8bfab9f20edbc455f7eb9b42e3c70e02" alt="A graphic showing a radio button group with four options and an error reading ‘Answer required’ displayed with an empty input field that is a conditional field of one of the radio buttons."
data:image/s3,"s3://crabby-images/c8e34/c8e3441cfee6ef328ea931de6ebdbf169035abce" alt="A graphic showing two error labels incorrectly applied to a radio button group. One error reading ‘Answer required’ is displayed with an empty input field that is the conditional field of a radio button. The other error, also reading ‘Answer required’ is displayed with the whole radio button group."
Content
Labels
Follow the