用户在给定范围内选择值的输入控件。
import * as React from "react";import { Slider } from "radix-ui";import "./styles.css";const SliderDemo = () => (<form><Slider.Root className="SliderRoot" defaultValue={[50]} max={100} step={1}><Slider.Track className="SliderTrack"><Slider.Range className="SliderRange" /></Slider.Track><Slider.Thumb className="SliderThumb" aria-label="Volume" /></Slider.Root></form>);export default SliderDemo;
可以受控或非受控。
支持多个滑块手柄。
支持滑块手柄之间的最小值。
支持触摸或点击轨道来更新值。
支持从右到左的方向。
完整的键盘导航。
从命令行安装组件。
导入所有部分并将它们组装在一起。
包含滑块的所有部分。当在表单中使用时,它将为每个滑块手柄渲染一个 input
元素,以确保事件正确传播。
包含 Slider.Range
的轨道。
范围部分。必须位于 Slider.Track
内。
可拖动的滑块手柄。您可以渲染多个滑块手柄。
使用 orientation
属性创建垂直滑块。
添加多个滑块手柄和值以创建范围滑块。
使用 step
属性增加步进间隔。
使用 minStepsBetweenThumbs
避免具有相等值的滑块手柄。
通过将原始部分抽象到您自己的组件中来创建您自己的 API。
此示例抽象了 Slider
的所有部分,因此可以将其用作自闭合元素。
由于我们在实现过程中遇到的限制,以下示例将无法按预期工作,并且 onMouseDown
和 onMouseUp
事件处理程序不会被触发
我们建议改用指针事件(例如 onPointerDown
,onPointerUp
)。 无论上述限制如何,这些事件都更适合跨平台/设备处理,因为它们适用于所有指针输入类型(鼠标、触摸、笔等)。