Checkbox
Checkbox
Introduction
An example of the checkbox component.
Interactive example
When to use
Use checkboxes to allow a user to select any number of options from a list. Checkboxes are grouped into a checkbox group to provide multiple options. Any number of options can be selected and any type of checkbox can be included within the checkbox group.
data:image/s3,"s3://crabby-images/930ed/930ed704f7adf73b279e4651baf3d32c0f2cfe0d" alt="A checklist asking the question ‘What are your favourite types of coffee?’ with six options where two are checked."
Use a single checkbox on its own to allow a user to agree with a statement. For example, use a single checkbox to allow a user to mark whether they agree to a terms and conditions statement.
data:image/s3,"s3://crabby-images/4e1c7/4e1c7b958cef6f56d0e598c9bb261c319c1216f7" alt="A single unchecked checkbox with a label that reads “I agree to the terms and conditions, and privacy statement”."
Use a checkbox with a conditional field to display a related additional element when that checkbox is selected. The conditional field can be set to static so that it is always visible and becomes enabled once the checkbox is selected. If the conditional field is set to dynamic the field is displayed only when the checkbox is selected.
When not to use
Don’t use checkboxes when only one option from a list can be selected. For single select lists, use
Interaction behaviour
Checkboxes have three possible selection states: selected, unselected and indeterminate.
Display the indeterminate selection state when the selection of child elements is mixed.
data:image/s3,"s3://crabby-images/a00b8/a00b80ce64be15e22be74774248ca03b6524d943" alt="A checkbox group asking ‘Which hot drinks do you like?’. A checkbox with label ‘coffee’ shows its indeterminate state as only one of its two child checkboxes is selected."
Checkboxes are selected or unselected by clicking any part of the checkbox, including the label.
Sizing
Use small sized checkbox groups for compact layouts. Always use small components with other small input components.
data:image/s3,"s3://crabby-images/084a5/084a510519f8c8b2e056f86364df32c99b1c7330" alt="Two forms containing a checklist and a text input. One uses default sizing resulting in larger spacing between components. The other uses small sizing that reduces space between components and results in a shorter vertical height for the same form."
Validation
There are two types of error that can occur on a checkbox: a checkbox input error or an error on a checkbox’s conditional field.
A checkbox input error is when the checkbox or checkbox group component itself is responsible for the error. This is shown using the checkbox error state.
data:image/s3,"s3://crabby-images/a8eb1/a8eb1735897172c5ccdcd946dae5b471a2a6e0f0" alt="A checklist asking 'What are your favourite types of coffee?' with helper text stating 'Select at least one'. Six options are shown but all are unchecked. An error message is displayed below the checklist reading 'Please select at least one option'."
data:image/s3,"s3://crabby-images/4f3ee/4f3eeac8833c10541d4ad1d1ff7344fdb1a75e5d" alt="An unchecked checkbox with label 'I agree to the terms and conditions and privacy statement' alongside a submit button. An error state is shown after the checkbox reading 'Please agree before continuing'."
For errors on a checkbox’s conditional field, the error is shown only on the conditional field itself and not the wider checkbox or checkbox group component.
data:image/s3,"s3://crabby-images/03d13/03d135a22454ebeeaae15f38aea11ba4d6ed4513" alt="A checklist asking ‘What are your favourite types of coffee’. Six options are shown and one labelled ‘Flat white’ is selected and shows a conditional field that asks ‘How frothy do you like it?’. An error message is displayed below the conditional field reading ‘Please provide an answer’."
data:image/s3,"s3://crabby-images/6e44e/6e44e43e834fff8b88c6f20f7d4e66b0bb7209bd" alt="A checklist asking ‘What are your favourite types of coffee?’. Six options are shown and one labelled ‘Flat white’ is selected and shows a child field that asks ‘How frothy do you like it?’. An error message is displayed below the child field reading ‘Please provide an answer’. Another error message is displayed below the checklist repeating the same error message."
Content
Labels
Follow the
Make sure to use labels that make it easy to understand what selecting the checkbox represents. Avoid using ambiguous labels that make it unclear whether to select a checkbox or not.
data:image/s3,"s3://crabby-images/c3f54/c3f54b05ae100372fbe68cfa3a3e6246e77bc2df" alt="A short form asking the user to agree to the terms and conditions. A single unchecked checkbox with label ‘I agree to the terms and conditions and privacy statement’ is shown alongside a submit button."
data:image/s3,"s3://crabby-images/9b384/9b38437672da98676e45fbd9fc5de9f0f46e5d1c" alt="A short form asking the user to agree to the terms and conditions. A single unchecked checkbox with label ‘These are our terms and conditions and privacy statement’ is shown alongside a submit button."