Slider
Sliders allow users to quickly select a value within a range. They should be used when the upper and lower bounds to the range are invariable.
data:image/s3,"s3://crabby-images/748ef/748ef283793017b5911e0a7a3b239d8bd94c9288" alt="Examples of sliders doing slider stuff."
data:image/s3,"s3://crabby-images/dab45/dab4588235d46a01fc7dc5ac8a70a2e5eeadd978" alt="Examples of several sliders in a mobile layout."
Anatomy#
data:image/s3,"s3://crabby-images/da204/da20497dbd1d34e265b1962853499ceaa3abfa8a" alt="Diagram of a Slider's anatomy, including label, track, handle, fill, and value."
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.
Behaviors#
data:image/s3,"s3://crabby-images/4aa97/4aa978c9bc84be03d3ceca4a1f0b73b1ec03a0b1" alt="Slider showing size of 24, with handle in focus."
Keyboard focus#
A slider can be navigated using a keyboard. The keyboard focus state takes the slider’s visual hover state and adds a blue ring to the slider handle in focus.
data:image/s3,"s3://crabby-images/f8af8/f8af8b2b4856b1f1cf5cb27f9ad86e9d5916c71f" alt="Examples of Sliders with placement of the value following placement of the label."
Value placement#
The value follows the placement of the label: on top when the label is on top, and on the side when the label is on the side. There is an exception to this rule when the value is editable, shown within a text field (standard or quiet style); in this case, the editable input is always placed on the side. This editable input should be labelled using "aria-labelledby" or "aria-label" as well.
data:image/s3,"s3://crabby-images/8a57c/8a57cc4b7a0ecca1540394ee5a48ab11433053d3" alt="Examples of two sliders, each with label Opacity and the slider handle positioned at the center of the slider track. The top slider has a non-editable value field. The bottom slider has an editable value field. The value fields for each slider contain an en dash."
Mixed value#
A slider representing multiple non-identical values appears as indeterminate, with an en dash (–) in place of the value. The handle position corresponds to the first selected value.
data:image/s3,"s3://crabby-images/95839/95839d25192b27ff67f7bc8fa08a5da16556973e" alt="Example of a Slider with overflowing label text."
Text overflow#
When the label is too long for the available horizontal space, it wraps to form another line.
data:image/s3,"s3://crabby-images/af377/af3778cd5c759db4a4e3498c4f511f23f45c91e6" alt="Animation showing a slider with label saturation, value 0. Slider handle is positioned in the center of the slider track. The slider handle is clicked and dragged to the right, stopping when the value reaches 50. The slider handle is then double-clicked and it returns automatically to it’s original position at value 0."
Double-click to reset#
After a slider has been adjusted, it can be reset to the default value by double-clicking the handle.
data:image/s3,"s3://crabby-images/058f6/058f697347972a85f35d9b21b4bb67f32654cc7b" alt="Key example of sliders in Windows “high contrast black” theme with label “Slider” and disabled slider with label “Disabled slider” both with value of 0."
Windows high contrast mode#
In Windows high contrast mode, sliders should be displayed using the high contrast theme-specified colors for buttons. By default, track and handle border colors should be the same as the button text color and labels should use default text color. In hover and keyboard focus states, the track and handle border colors should display as the button border color. In the disabled state, border and text color should display as the disabled color.
Usage guidelines#
Include a label#
Every slider should have a label. A slider without a label is ambiguous and not accessible. Write the label in sentence case.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/205e3/205e344335509c5d5df35ecbec67ed85d7a10bb5" alt="Example of a correct Slider that includes a label."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/f2cdf/f2cdfacfb17442410f84ccda45adc01be612894e" alt="Example of an incorrect Slider which has no label."
Review label-less designs#
In rare cases where context is sufficient and a label could be absent, make sure to have the design reviewed and approved by an accessibility expert. These should still include an aria-label in HTML (depending on the context, “aria-label” or “aria-labelledby”).
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/c985b/c985b00e3b0fe30d8d302becfd3ec55b4d1ab27b" alt="Example of a Slider without a label that passed inclusivity review as an exception."
Allow a hot text option when needed#
In addition to dragging the handle, sliders can provide more ways to change the value (known as “hot text”) either by clicking on the value text and dragging up/down, or by scrolling up/down while hovering over the value text.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/bcefb/bcefb66bd30544ef4e0910f14316ba373f429baf" alt="Example of a Slider with hot text enabled."
Show value units to help provide context#
Slider values can be shown with a unit when it helps provide context (e.g., “%” or “px”). When the value is shown within a text field, the unit disappears on focus.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/0a8da/0a8dafbd51a5a6ba1364eb5edca066a84604c7b9" alt="Example of a Slider with units included for context."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/52187/5218742d51c21ee352164615cac78b44333d1dba" alt="Example of a confusing Slider that does not include units for context."
Prefix positive/negative values#
If the value ranges from negative to positive, prefix the value with a plus (+) or minus (-) sign. When the sign is shown within a text field, it remains visible on focus. When the sign is shown outside the text field, there should be a space between the sign and the numerical value for readability.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/00239/002393e8de1121b95933b55c7bb6de237a98e0bd" alt="Examples of Sliders with correct implementation of positive and negative prefixes."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/2f46d/2f46dad9ca315f9cd807c7db1bb69a06af4001e7" alt="Example of poorly implemented Sliders that are missing positive and negative prefixes."
Internationalization#
Keyboard interactions#
Changelog#
- Updated all colors to 6.0.0
- Added double-click to reset
- Added mixed value
- Added min value, max value, and step options
- Added progression scale option
- Updated keyboard focus state to be more accessible
- Added text overflow behavior
- This component is now individually versioned (individual versions of existing components start at 5.0.0)
- Added RTL (right-to-left) guidelines
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/67464/674640c106412597f4de10db2d7f6d1cd0de6619" alt="unchecked"
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/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
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/4c3e2/4c3e27966f87ffa66607575c8ece77aa58b15ed7" alt="check"
In Spectrum for Adobe XD plugin
Component is included in the Spectrum for Adobe XD plugin.