To add a slider widget to your page, use a standard input with the type="range" attribute. The input's value is used to configure the starting position of the handle and the value is populated in the text input. Specify min and max attribute values to set the slider's range. If you want to constrain input to specific increments, add the step attribute. Set the value attribute to define the initial value. The framework will parse these attributes to configure the slider widget. View the data- attribute reference to see all the possible attributes you can add to sliders.
input
type="range"
value
min
max
step
As you drag the slider's handle, the framework will update the native input's value (and vice-versa) so they are always in sync; this ensures that the value is submitted with the form.
Set the for attribute of the label to match the id of the input so they are semantically associated. It's possible to accessibly hide the label if it's not desired in the page layout, but we require that it is present in the markup for semantic and accessibility reasons.
for
label
id
The framework will find all input elements with a type="range" and automatically enhance them into a slider with an accompanying input without any need to apply a data-role attribute. To prevent the automatic enhancement of this input into a slider, add data-role="none" attribute to the input and wrap them in a div with the data-role="fieldcontain" attribute to group them. In this example, the acceptable range is 0-100.
data-role
data-role="none"
div
data-role="fieldcontain"
<label for="slider-1">Input slider:</label> <input type="range" name="slider-1" id="slider-1" value="60" min="0" max="100" />
The default slider with these settings is displayed like this:
To force the slider to snap to a specific increment, add the step attribute to the input. By default, the step is 1, but in this example, the step is 50 and the maximum value is 500.
<label for="slider-step">Input slider:</label> <input type="range" name="slider-step" id="slider-step" value="150" min="0" max="500" step="50" />
This will produce an input that snaps to increments of 50. If a value is added to the input that isn't valid with the step increment, the value will be reset on blur to the closest step.
To have a highlight fill on the track up to the slider handle position, add the data-highlight="true" attribute to the input. The fill uses the active state swatch.
data-highlight="true"
<label for="slider-fill">Input slider:</label> <input type="range" name="slider-fill" id="slider-fill" value="60" min="0" max="100" data-highlight="true" />
For a more compact version that is useful in toolbars and tight spaces, add the data-mini="true" attribute to the element to create a mini version.
data-mini="true"
<label for="slider-mini">Input slider:</label> <input type="range" name="slider-mini" id="slider-mini" value="25" min="0" max="100" data-highlight="true" data-mini="true" />
This will produce a slider and its corresponding input that are not as tall as the standard version. The input also has a smaller text size.
Optionally wrap the slider markup in a container with the data-role="fieldcontain" attribute to help visually group it in a longer form. In this example, the step attribute is omitted to allow any whole number value to be selected.
<div data-role="fieldcontain"> <label for="slider-2">Input slider:</label> <input type="range" name="slider-2" id="slider-2" value="25" min="0" max="100" /> </div>
The slider is now displayed like this:
Sliders also respond to key commands. Right Arrow, Up Arrow and Page Up keys increase the value; Left Arrow, Down Arrow and Page Down keys decrease it. To move the slider to its minimum or maximum value, use the Home or End key, respectively.
This plugin will auto initialize on any page that contains a text input with the type="range" attribute. However, if needed you can directly call the slider plugin on any selector, just like any jQuery plugin:
slider
$('input').slider();
To set the theme swatch for the slider, add a data-theme attribute to the input which will apply the theme to both the input, handle and track. The track swatch can be set separately by adding the data-track-theme attribute to apply the down state version of the selected button swatch.
data-theme
data-track-theme
<div data-role="fieldcontain"> <label for="slider-3">Input slider:</label> <input type="range" name="slider-3" id="slider-3" value="25" min="0" max="100" data-theme="a" data-track-theme="b" /> </div>
This will produce a themed slider: