Horizontal Multi-Thumb Slider Example

Important Note About Use of This Example

Note: This is an illustrative example of one way of using ARIA that conforms with the ARIA specification.

WARNING! Some users of touch-based assistive technologies may experience difficulty utilizing widgets that implement this slider pattern because the gestures their assistive technology provides for operating sliders may not yet generate the necessary output. To change the slider value, touch-based assistive technologies need to respond to user gestures for increasing and decreasing the value by synthesizing key events. This is a new convention that may not be fully implemented by some assistive technologies. Authors should fully test slider widgets using assistive technologies on devices where touch is a primary input mechanism before considering incorporation into production systems.

The following example of the multi-thumb slider design pattern demonstrates an input for setting a pair of values that represent a range. This example enables users to specify a price range for a hotel reservation by moving the two arrows (thumbs) that represent the minimum and maximum price.

Similar examples include:

Example

Hotel Price Range (in USD)

$100 $250

Accessibility Features

Keyboard Support

Key Function
Right Arrow Increases slider value one step.
Up Arrow Increases slider value one step.
Left Arrow Decreases slider value one step.
Down Arrow Decreases slider value one step.
Page Up Increases slider value multiple steps. In this slider, jumps ten steps.
Page Down Decreases slider value multiple steps. In this slider, jumps ten steps.
Home Sets slider to its minimum value.
End Sets slider to its maximum value.

Role, Property, State, and Tabindex Attributes

Role Attribute Element Usage
none svg The use of the none role on the SVG element ensures assistive technologies do not interpret the SVG element as an image or some other role.
slider g
  • Identifies the img element as a slider.
  • Set on the movable thumb because it is the operable element that receives focus and represents the slider value.
tabindex=0 g Includes the slider thumb in the page tab sequence.
aria-valuemax=NUMBER g Specifies the maximum value of the slider.
aria-valuemin=NUMBER g Specifies the minimum value of the slider.
aria-valuenow=NUMBER g Indicates the current value of the slider.
aria-label=text g A label identifying the purpose of the slider, e.g., Hotel Minimum Price.
aria-hidden=true g Removes the SVG g element from the accessibility tree to prevent assistive technologies from presenting it as an image separate from the slider.

Javascript and CSS Source Code

HTML Source Code

<h3>
  Hotel Price Range (in
  <abbr title="United States Dollars">
    USD
  </abbr>
  )
</h3>
<div class="slider-multithumb">
  <svg role="none"
       class="slider-group"
       width="360"
       height="60">
    <g aria-hidden="true" class="rail">
      <rect height="0" width="0"></rect>
    </g>
    <g aria-hidden="true" class="range">
      <rect height="0" width="0"></rect>
    </g>
    <g class="minimum"
       role="slider"
       tabindex="0"
       aria-valuemin="0"
       aria-valuenow="100"
       aria-valuemax="250"
       aria-label="Hotel Minimum Price in US dollars">
      <text class="value">
        0
      </text>
      <rect class="focus-ring"
            height="0"
            width="0"></rect>
      <polygon class="thumb" points="0,0 0,0"></polygon>
    </g>
    <g class="maximum"
       role="slider"
       tabindex="0"
       aria-valuemin="100"
       aria-valuenow="250"
       aria-valuemax="400"
       aria-label="Hotel Maximum Price in US dollars">
      <text class="value">
        0
      </text>
      <rect class="focus-ring"
            height="0"
            width="0"></rect>
      <polygon class="thumb" points="0,0 0,0"></polygon>
    </g>
  </svg>
</div>