The Slider is used to allow users to make selections from a range of values.

50

class SliderState(rx.State):
    value: int = 50


def slider_example():
    return rc.vstack(
        rc.heading(SliderState.value),
        rc.slider(on_change=SliderState.set_value),
        width="100%",
    )

You can also combine all three event handlers: on_change, on_change_start, and on_change_end.

50

class SliderCombo(rx.State):
    value: int = 50
    color: str = "black"

    def set_start(self, value):
        self.color = "#68D391"

    def set_end(self, value):
        self.color = "#F56565"


def slider_combo_example():
    return rc.vstack(
        rc.heading(
            SliderCombo.value, color=SliderCombo.color
        ),
        rc.slider(
            on_change_start=SliderCombo.set_start,
            on_change=SliderCombo.set_value,
            on_change_end=SliderCombo.set_end,
        ),
        width="100%",
    )

You can also customize the appearance of the slider by passing in custom components for the track and thumb.

Weather is 50 degrees

class SliderManual(rx.State):
    value: int = 50

    def set_end(self, value: int):
        self.value = value


def slider_manual_example():
    return rc.vstack(
        rc.heading(
            f"Weather is {SliderManual.value} degrees"
        ),
        rc.slider(
            rc.slider_track(
                rc.slider_filled_track(bg="tomato"),
                bg="red.100",
            ),
            rc.slider_thumb(
                rc.icon(tag="sun", color="white"),
                box_size="1.5em",
                bg="tomato",
            ),
            on_change_end=SliderManual.set_end,
        ),
        width="100%",
    )

If you want to trigger state change on every slider movement, you can use the on_change event handler.

For performance reasons, you may want to trigger state change only when the user releases the slider by using the on_change_end event handler, but if you need perform an event on every slider movement, you can use the on_change event handler.

50

rc.vstack(
    rc.heading(SliderState.value),
    rc.slider(on_change=SliderState.set_value),
    width="100%",
)

rc.Slider

The wrapper that provides context and functionality for all children.

PropType | ValuesDefault
value
int
color_scheme
str
default_value
int
direction
"ltr" | "rtl"
focus_thumb_on_change
bool
is_disabled
bool
is_read_only
bool
is_reversed
bool
min_
int
max_
int
step
int
min_steps_between_thumbs
int
orientation
"horizontal" | "vertical"
min_h
str
min_w
str
max_h
str
max_w
str
name
str

Event Triggers

See the full list of default event triggers
TriggerDescription
on_change Fired when the value changes.
on_change_start Fired when the value starts changing.
on_change_end Fired when the value stops changing.

rc.SliderTrack

The empty part of the slider that shows the track.

Props

No component specific props

rc.SliderFilledTrack

The filled part of the slider.

Props

No component specific props

rc.SliderThumb

The handle that's used to change the slider value.

PropType | ValuesDefault
box_size
str

rc.SliderMark

The label or mark that shows names for specific slider values.

Props

No component specific props