GC Design System Components
Home Start to use Page templates overview Basic page Components overview Breadcrumbs Button Card Checkboxes Container Date input Date modified Details Error message Error summary Fieldset File uploader Footer Grid Header Heading Icon Input Language toggle Link Notice Pagination Radios Screenreader-only Search Select Side navigation Signature Stepper Text Textarea Theme and topic menu Top navigation CSS shortcuts overview Reset styles Responsive layout State Box sizing Container sizing Display Overflow Position Visibility Font Font family Font size Font style Font weight Line height Link colour Link size Link text decoration List style Text align Text colour Text overflow Text transform Word break Margin Padding Align content Align items Align self Flex Flex direction Flex grow Flex shrink Flex wrap Gap Grid columns Grid rows Justify content Justify items Justify self Order Place content Place items Place self Background colour Border colour Border radius Border style Border width Icon names Icon size Image Cursor Pointer events Transition Styles overview Design tokens Colour tokens Spacing tokens Typography tokens Contact us Get involved Find a demo

Checkbox
<gcds-checkbox>

This component is deprecated as of v0.35.0. Please see Release v0.35.0 for details.

Also called: checklist, check list.

A checkbox is a set of options for one or multiple selections.


Build a checkbox

Use a checkbox with a fieldset when you are expecting the user to select more than one option from a short list of items in response to a question or instruction.

Coding and accessibility for checkboxes

Apply required attributes

For the checkbox to function properly, always use the following attributes with <gcds-checkbox>:

  • name
  • label
  • checkbox-id

Use a fieldset and the required attribute

  • Group checkbox options and name the group using the fieldset component.
  • Use the fieldset legend and hint attributes for the group name and instructions.
  • For required groups, set the required attribute in the fieldset. Setting the required attribute applies validation and error handling to the checkbox group.

For a single checkbox

  • Avoid using a fieldset for checkboxes with a single box to check, like for a confirmation the terms of reference was read prior to registration.
  • Use the required attribute to activate the required validator. Validation will happen by default on the onBlur event.
  • If you need to change the validation event, use the validate-on attribute. Validation can happen on blur, when the element loses focus, or manually with the validate method.
  • Use the required attribute when a single checkbox need to be filled in. This places "(required)" at the end of the checkbox .
  • Keep the default error-message attribute for a required single checkbox that needs validation. Missing entry will prompt an inline error message.
  • Remove the default error-message attribute if the checkbox is optional.

Help us improve

Have questions or a request? Give feedback on our contact form.

Something's wrong? Raise it through GitHub with an account. You'll have access to the team's direct responses, progress made on your issue, and issues raised by others.

Give feedback Report an issue on GitHub
2025-06-04