滑块
一个用于从范围中选择值的 SwiftUI Slider 组件。
For the complete documentation index, see llms.txt. Use this Use this file to discover all available pages.
Expo UI Slider 与官方 SwiftUI Slider API 保持一致,并允许从有界范围中选择数值。
安装
- npx expo install @expo/uiIf you are installing this in an existing React Native app, make sure to install expo in your project.
使用
注意:
Slider是一个可变宽度组件,它会扩展以填充可用的水平空间,并且没有固有宽度。 当在Host上使用matchContents时,你应该在Slider上应用frame修饰符,为其提供一个明确的宽度。或者,也可以使用style为Host提供一个明确的尺寸(例如,style={{ width: 300 }}或style={{ flex: 1 }}),或者将Slider放在像Form这样提供宽度约束的 SwiftUI 容器中。
基础滑块
import { useState } from 'react'; import { Host, Slider } from '@expo/ui/swift-ui'; export default function BasicSliderExample() { const [value, setValue] = useState(0.5); return ( <Host style={{ flex: 1 }}> <Slider value={value} onValueChange={setValue} /> </Host> ); }
自定义范围的滑块
import { useState } from 'react'; import { Host, Slider } from '@expo/ui/swift-ui'; export default function CustomRangeSliderExample() { const [value, setValue] = useState(50); return ( <Host style={{ flex: 1 }}> <Slider value={value} min={0} max={100} onValueChange={setValue} /> </Host> ); }
带步长的滑块
使用 step 属性来定义离散增量。将 step 设置为 0 可表示连续值。
import { useState } from 'react'; import { Host, Slider } from '@expo/ui/swift-ui'; export default function SteppedSliderExample() { const [value, setValue] = useState(0); return ( <Host style={{ flex: 1 }}> <Slider value={value} min={0} max={100} step={10} onValueChange={setValue} /> </Host> ); }
带标签的滑块
你可以添加标签来描述滑块的用途,并标记最小值和最大值的位置。
import { useState } from 'react'; import { Host, Slider, Text } from '@expo/ui/swift-ui'; export default function LabeledSliderExample() { const [value, setValue] = useState(50); return ( <Host style={{ flex: 1 }}> <Slider value={value} min={0} max={100} label={<Text>音量</Text>} minimumValueLabel={<Text>0</Text>} maximumValueLabel={<Text>100</Text>} onValueChange={setValue} /> </Host> ); }
API
import { Slider } from '@expo/ui/swift-ui';
Component
Type: React.Element<SliderProps>
numberThe maximum value of the slider. Updating this value does not trigger callbacks if the current value is above max.
React.ReactNodeA label displayed at the maximum value position.
numberThe minimum value of the slider. Updating this value does not trigger callbacks if the current value is below min.
React.ReactNodeA label displayed at the minimum value position.
(isEditing: boolean) => voidCallback triggered when the user starts or ends editing the slider.
(value: number) => voidCallback triggered on dragging along the slider.