The Current State of HTML5 Forms

The range Type

<input type=range min=10 max=30 value=10 step=1>
<input type=range multiple min=0 max=10 step="0.2" value="3,5">

Live Demo


Safari Mobile
Single Slider Supported Supported Supported Supported Supported Supported Supported
Multiple No support No support No support No support No support No support No support

Supported Browser Screenshots

Chrome without and with list attribute
IE 11 without and with list attribute.

The Low Down

The range input provides for a slider UI that submits is a number: it's for "imprecise" control, or where the specific number chosen is more relative rather than needing to be exact.

  • Opera, Safari, Firefox and Chrome provide for a grey slider track with a circular thumb, which is blue in Safari and grey everywhere else. IE, on the other hand, provides for a rectangular blue and grey range track with a black square thumb.
  • By default, other than in IE, there are no ticks along the slider path. To create ticks along the slider, create a <datalist> with all the values and add the list attribute to point to that datalist. In the case of an associated datalist, all browsers that support tick marks will present a tick mark for each valid <option> values in the associated <datalist>.
  • If no list attribute is present, IE will include ticks based on the step attribute with a maximum of 6 ticks, remembering the default value for step is 1, starting with the first tick at the minimum value, and the last tick being the maximum value if both are valid. No ticks will be displayed if step="any".
  • IE is the only browser displaying the actual number currently selected: as the user slides the thumb along the track, the current value is displayed as a tool tip. Other browsers don't indicate the current value, which is OK as the spec says range inputs are for data where exact value isn't important.
  • Validation/required is irrelevant since a slider will always have a valid value - the UI slider does not allow for selecting invalid values.
  • Falls back to a regular text input, which is not very useful as that has no pre-determined choices as ranges do. A polyfill involves a select element and some JavaScript.
  • If no value is provided, the default value of the field to be half-way between the min and max values, if present.
  • It is possible to create a vertical slider. The default method will eventually be to simply declare a width that is narrower than the height. Until vertical ranges are detected automatically, specific styles will convince browsers. For now, include orient="vertical" attribute/value for Firefox (see bug report), -webkit-appearance: slider-vertical; in the style declaration for Safari, Chrome and Opera, and writing-mode: bt-lr; in your styles for Internet Explorer.
    <input type="range" name="grade" orient="vertical"
      style="width: 20px; height: 200px;
      -webkit-appearance: slider-vertical;
      writing-mode: bt-lr;">
  • The multiple attribute, when supported on type="range", will allow for two sliders.