t-slider
Slider 滑块
组件介绍
t-slider 是一个基于 Canvas 绘制的滑块组件,支持水平/垂直方向、单滑块/多滑块、显示数值/百分比等丰富功能。适用于音量调节、亮度调节、价格区间选择等场景。
平台兼容
| Harmony | H5 | Android | iOS | 小程序 | UTS |
|---|---|---|---|---|---|
| ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
基础用法
基础用法参考 demo/slider/slider.uvue,通过 v-model 双向绑定滑块值。
vue
<template>
<view class="slider-demo">
<!-- 单滑块 -->
<t-slider v-model="value1" :min="0" :max="100"></t-slider>
<!-- 显示数值 -->
<t-slider v-model="value2" :showValue="true" :decimalPlaces="1"></t-slider>
<!-- 显示百分比 -->
<t-slider v-model="value3" :showValuePosition="true"></t-slider>
<!-- 多滑块(区间选择) -->
<t-slider v-model="rangeValue" :min="0" :max="1000"></t-slider>
<!-- 垂直滑块 -->
<t-slider v-model="value4" direction="vertical" :showValue="true"></t-slider>
</view>
</template>
<script setup>
const value1 = ref([50]);
const value2 = ref([30]);
const value3 = ref([70]);
const rangeValue = ref([200, 800]);
const value4 = ref([60]);
</script>
<style scoped>
.slider-demo {
padding: 40rpx;
}
.slider-demo t-slider {
margin-bottom: 60rpx;
}
</style>Props
| 属性名 | 说明 | 类型 | 默认值 |
|---|---|---|---|
path | 点击组件后跳转的页面路径;为空时仅响应事件 | string | '' |
hover | 是否启用点击效果 | boolean | false |
type | 组件主题类型,可选 info、primary、error、warning、success | string | 'primary' |
disabled | 是否禁用 | boolean | false |
effect | 组件显示主题,可选 normal、dark、light、plain | string | 'normal' |
size | 组件尺寸,可选 large、medium、small、mini | string | '' |
direction | 滑块方向,可选 horizontal、vertical | string | 'horizontal' |
min | 最小值 | number | 0 |
max | 最大值 | number | 100 |
modelValue | 双向绑定的值,数组格式支持多滑块 | number[] | [] |
activeColor | 已选择部分的颜色 | string | ''(使用主题色) |
inactiveColor | 未选择部分的颜色 | string | '#f2f2f2' |
blockSize | 滑块按钮的大小 | string | '50' |
fontSize | 数值显示字体大小 | string | '28rpx' |
showValue | 是否显示具体数值 | boolean | false |
showValuePosition | 是否显示百分比 | boolean | true |
decimalPlaces | 保留的小数位数 | number | 0 |
trackSize | 滑块轨道尺寸 | string | '5' |
showMode | 数值显示位置,可选 before(滑块前)、after(滑块后) | string | 'before' |
Events
| 事件名 | 说明 | 回调参数 |
|---|---|---|
update:modelValue | 值更新时触发 | number[] |
change | 值发生变化时触发 | number[] |