Radio group
A radio group is a grouping of radio buttons that are related to each other.
data:image/s3,"s3://crabby-images/6513c/6513c26e65b88b39c8029fc0fec314a0b9208a56" alt="Example of a radio group with description and error text. Required radio group, label Size. 3 radio buttons, labels Small, Medium, Large. Description and error text, select a product size."
Anatomy#
data:image/s3,"s3://crabby-images/f7d90/f7d90aa8286897c2c839bf89e9a68d15a40fc63f" alt="Diagram showing the component parts of a radio group, including its field label, radio button area, and help text."
Options#
Table of options#
From the design point of view, each component has a number of options. These options and their names are platform agnostic, and each implementation should adapt these to fit into their framework.
Composition#
Behaviors#
data:image/s3,"s3://crabby-images/20bd1/20bd17f10db834e221b06491df6568789c83ab87" alt="Key example of the keyboard focus behavior for radio buttons. Radio button with placeholder label, not selected, in focus."
Keyboard focus#
A radio button can be navigated using a keyboard. The keyboard focus state takes the radio button’s visual hover state and adds a blue ring to the radio button in focus.
data:image/s3,"s3://crabby-images/7e4b5/7e4b5ed65e83222321a9c95637205338265952b8" alt="Key example of the text overflow behavior for radio buttons. A selected and emphasized radio button is placed on the left of a long radio button label text. The long text breaks into a new line and is flushed-left at the same column as the first word of the label."
Text overflow#
When a radio button's label is too long for the horizontal space available, it wraps to form another line.
data:image/s3,"s3://crabby-images/500d9/500d9bdf330af378a97b3699c7e6875616f0363a" alt="Key example of the mixed value behavior for radio buttons. For the radio button group, Label Size, there are three radio buttons labels Small, Medium, Large. All are unselected."
Mixed value#
When a radio button group presents multiple values that are not identical, the group should not show a selection. Any subsequent selection should update all values.
data:image/s3,"s3://crabby-images/6a29b/6a29b2f9d0980a0ed5a32243f92d8442fba492d0" alt="Key example of radio in Windows “high contrast black” theme with label “Radio button”, selected radio with label “Selected radio button”, and disabled radio with label “Disabled radio button”."
Windows high contrast mode#
In Windows high contrast mode, radio buttons should be displayed using the high contrast theme-specified colors for buttons. By default, borders should be same as the button text color and labels should use default text color. In hover and keyboard focus states, a border should display as the button border color. Selected radio fill should be the same as button border color. In the disabled state, border and text color should display as the disabled color.
Usage guidelines#
Emphasized or not?#
Emphasized radio buttons are best for forms, settings, and other scenarios where the radio buttons need to be noticed.
Not emphasized radio buttons are best for application panels where all the visual components are monochrome in order to direct focus to the canvas.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/810d4/810d456e804057f8a19e16b1cbb1a7095f3c5833" alt="Key example showing correct usage of emphasized radio buttons. The first radio button group for selecting a size features three radio buttons, first one is selected with a wider outline in blue show the emphasized option. The second radio button group shows two radio buttons in the not emphasized option inside an application panel. The second radio button is selected in gray to select the scrolling to vertical in the panel."
Use radio buttons for mutually exclusive options#
Radio buttons and
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/380de/380dea52595e602af977928a6f1fcb02f141585d" alt="Key example showing the correct usage for radio buttons. Three radio buttons with the label "small", "medium" and "large" select the size. The first radio button is selected."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/f19f0/f19f063c36e5a84c5543c00e7c5c67788f9743f7" alt="Key example of incorrect usage of radio buttons. A radio button group, label Interests, includes 3 radio buttons, labels Travel, Music, Shopping. These options would be better shown as a checkbox group."
Always label radio groups#
Radio groups should always have a label that clearly describes what the list of options represents. This is important for accessibility, since a screen reader will read the label before each option. Make sure to include a label, and don't assume that the options are self-explanatory without one. Write the label in
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/6fa31/6fa3103fcce8a3ae4a19d0ee1a29d04399481e03" alt="Key example showing the correct usage of label groups of radio button. The three radio buttons "Homepage", "Gallery" and "Contact us" are label with the text "Landing page". The first radio button is selected."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/5dfb5/5dfb5cc89b2b44a59e45cda6b36f74618f851ea0" alt="Key example showing the incorrect usage of label groups of radio button. The three radio buttons "Tomorrow", "In 3 days" and "Next week" are missing a label group. The first radio button is selected."
Internationalization#
Keyboard interactions#
Changelog#
- Updated read-only option design
- Updated disabled text color (from gray-500 to gray-400)
- Updated all colors to 6.0.0
- Updated read-only option design
- This component has been added to the website
- Updated documentation for Radio button to Radio group
Design checklist#
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
All interactive states
Includes all interactive states that are applicable (hover, down, focus, keyboard focus, disabled).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
All color themes
Works properly across all four color themes (lightest, light, dark, darkest).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
All platform scales
Includes a desktop scale (UWP, macOS, web desktop) and a mobile scale (iOS, Android, web mobile).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Accessible use of color
Color is not used as the only visual means of conveying information (WCAG 2.0 1.4.1).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Accessible contrast for text
Text has a contrast ratio of at least 4.5:1 for small text and at least 3:1 for large text (WCAG 2.0 1.4.3).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Accessible contrast for UI components
Visual information required to identify components and states (except inactive components) has a contrast ratio of at least 3:1 (WCAG 2.1 1.4.11).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Content design
UI language and information design considerations have been incorporated into component design.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Defined options
Includes relevant options (variant, style, size, orientation, optional iconography, decorations, selection, error state, etc.)
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Defined behaviors
Includes guidelines for keyboard focus, layout (wrapping, truncation, overflow), animation, interactions, etc.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Usage guidelines
Includes a list of dos and don'ts that highlight best practices and common mistakes.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Writing guidelines
Includes content standards or usage guidelines for how to write or format in-product content for the component.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Internationalization guidelines
Works properly across various locales and includes guidelines for bi-directionality (RTL).
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Keyboard interactions
Follows WCAG 2.0 standards for keyboard accessibility guidelines and includes a description of the keyboard interactions.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
Design tokens
All design attributes (color, typography, layout, animation, etc.) are available as design tokens.
data:image/s3,"s3://crabby-images/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
UI kit
Includes a downloadable XD file that shows multiple options, states, color themes, and platform scales.
data:image/s3,"s3://crabby-images/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
Generated UI kit
Includes a downloadable XD file, generated by code using design tokens defined in Spectrum DNA, and shows multiple options, states, color themes, and platform scales.
data:image/s3,"s3://crabby-images/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
In Spectrum for Adobe XD plugin
Component is included in the Spectrum for Adobe XD plugin.