React Range Slider Component

Range Slider

Christmas Tree
Merry Christmas & Happy New Year
Extra 25% off for all sale items + Free CoreUI Icons PRO with every order!
Limited offer ends 1st January 2025, use code 2024XMAS25 during checkout.
CoreUI PRO for React.js
This Component is a part of CoreUI PRO for React.js, an advanced UI library offering over 100 components designed for creating responsive, sleek, and powerful applications. Experience it yourself by signing up for a complimentary 7-day trial.

Enhance your forms with our customizable React Range Slider component for advanced range selection.

Other Frameworks

CoreUI components are available as native Angular, Bootstrap (Vanilla JS), and Vue components. To learn more please visit the following pages.

Overview#

The React Range Slider component allows users to select a value or range of values within a predefined range. Unlike the standard <input type="range">, the Range Slider offers enhanced customization options, including multiple handles, labels, tooltips, and vertical orientation. It ensures consistent styling across browsers and provides a rich set of features for advanced use cases.

25
75
Low
Medium
High

Features#

  • Multiple Handles: Select single or multiple values within the range.
  • Custom Labels: Display labels at specific points on the slider.
  • Tooltips: Show dynamic tooltips displaying current values.
  • Vertical Orientation: Rotate the slider for vertical layouts.
  • Clickable Labels: Enable users to click on labels to set slider values.
  • Disabled State: Disable the slider to prevent user interaction.

Basic React Range Slider#

Create a simple range slider with default settings.

50

Multiple handles#

Enable multiple handles to allow the selection of a range or/and multiple values.

20
40
20
40
60
20
40
60
80

Vertical Range Slider#

Rotate the slider to a vertical orientation.

20
20
80
20
80
100

Disabled#

Disable the slider to prevent user interaction.

50
50
75

Min and max#

React Range Slider component has implicit values for min and max0 and 100, respectively. You may specify new values for those using the min and max attributes.

50
50
75

Steps#

Range Slider inputs automatically "snap" to whole numbers. To modify this behavior, set a step value. In the example below, we increase the number of steps by specifying step="0.25".

50
50
75

Distance#

Sets the minimum distance between multiple slider handles by setting distance and ensures that the handles do not overlap or get too close.

50
75

Labels#

Add labels to specific points on the slider for better context. If you provide an array of strings, as in the example below, then labels will be spaced at equal distances from the beginning to the end of the slider.

30
70
Start
Middle
End

Labels customization#

Labels can be configured as an array of strings or objects. When using objects, you can specify additional properties like value, label, className, and style.

-10°C
40°C
-50°C
0°C
20°C
100°C

Clickable labels#

By default, users can click on labels to set the slider to specific values. You can disable this feature by setting clickableLabels to false.

20
80
Low
Medium
High

Tooltips#

By default, tooltips display the current value of each handle. You can disable tooltips by setting tooltips to false

Tooltips formatting#

Customize the content of tooltips using the tooltipsFormat option. This can be a function that formats the tooltip text based on the current value.

$100
$350
$0
$250
$500
$1000
50
50
75
25
50
75

Track#

The track property allows you to customize how the slider's track is displayed. By default, the track property is set to 'fill' enabling dynamic filling of the track based on the slider's current value(s). This means the filled portion of the track will adjust automatically as the slider handle(s) move, offering a responsive visual representation of the selected range.

Disable filling#

If you set track to false, the slider's track will not display any fill. Only the default track background will be visible, which can be useful for minimalist designs or when you use more then two handles.

50
50
75
25
50
75

Accessibility#

The React.js Range Slider component is built with accessibility in mind. Each slider handle includes the following ARIA attributes:

  • role="slider"
  • aria-valuemin: Minimum value
  • aria-valuemax: Maximum value
  • aria-valuenow: Current value
  • aria-orientation: horizontal or vertical

Additionally, ensure that labels and tooltips are clear and descriptive to provide the best experience for all users.

API#

Check out the documentation below for a comprehensive guide to all the props you can use with the components mentioned here.