Slider 滑块

介绍

滑动输入条,用于在给定的范围内选择一个值。

引入

  1. import { createApp } from 'vue';
  2. import { Slider } from 'vant';
  3. const app = createApp();
  4. app.use(Slider);

代码演示

基础用法

  1. <van-slider v-model="value" @change="onChange" />
  1. import { ref } from 'vue';
  2. import { Toast } from 'vant';
  3. export default {
  4. setup() {
  5. const value = ref(50);
  6. const onChange = (value) => {
  7. Toast('当前值:' + value);
  8. };
  9. return {
  10. value,
  11. onChange,
  12. };
  13. },
  14. };

双滑块

添加 range 属性就可以开启双滑块模式,确保 value 的值是一个数组。

  1. <van-slider v-model="value" range @change="onChange" />
  1. import { ref } from 'vue';
  2. import { Toast } from 'vant';
  3. export default {
  4. setup() {
  5. // 双滑块模式时,值必须是数组
  6. const value = ref([10, 50]);
  7. const onChange = (value) => {
  8. Toast('当前值:' + value);
  9. };
  10. return {
  11. value,
  12. onChange,
  13. };
  14. },
  15. };

指定选择范围

  1. <van-slider v-model="value" :min="-50" :max="50" />

禁用

  1. <van-slider v-model="value" disabled />

指定步长

  1. <van-slider v-model="value" :step="10" />

自定义样式

  1. <van-slider v-model="value" bar-height="4px" active-color="#ee0a24" />

自定义按钮

  1. <van-slider v-model="value" active-color="#ee0a24">
  2. <template #button>
  3. <div class="custom-button">{{ value }}</div>
  4. </template>
  5. </van-slider>
  6. <style>
  7. .custom-button {
  8. width: 26px;
  9. color: #fff;
  10. font-size: 10px;
  11. line-height: 18px;
  12. text-align: center;
  13. background-color: #ee0a24;
  14. border-radius: 100px;
  15. }
  16. </style>

垂直方向

设置 vertical 属性后,滑块会垂直展示,且高度为 100% 父元素高度。

  1. <div :style="{ height: '150px' }">
  2. <van-slider v-model="value" vertical @change="onChange" />
  3. <van-slider
  4. v-model="value2"
  5. range
  6. vertical
  7. style="margin-left: 100px;"
  8. @change="onChange"
  9. />
  10. </div>
  1. import { ref } from 'vue';
  2. import { Toast } from 'vant';
  3. export default {
  4. setup() {
  5. const value = ref(50);
  6. const value2 = ref([10, 50]);
  7. const onChange = (value) => {
  8. Toast('当前值:' + value);
  9. };
  10. return {
  11. value,
  12. value2,
  13. onChange,
  14. };
  15. },
  16. };

API

Props

参数说明类型默认值
value当前进度百分比number | array0
max最大值number | string100
min最小值number | string0
step步长number | string1
bar-height进度条高度,默认单位为pxnumber | string2px
button-size v2.4.5滑块按钮大小,默认单位为pxnumber | string24px
active-color进度条激活态颜色string#1989fa
inactive-color进度条非激活态颜色string#e5e5e5
range是否开启双滑块模式booleanfalse
disabled是否禁用滑块booleanfalse
vertical是否垂直展示booleanfalse

Events

事件名说明回调参数
update:model-value进度变化时实时触发value: 当前进度
change进度变化且结束拖动后触发value: 当前进度
drag-start开始拖动时触发-
drag-end结束拖动时触发-

Slots

名称说明
button自定义滑动按钮

样式变量

组件提供了下列 Less 变量,可用于自定义样式,使用方法请参考主题定制

名称默认值描述
@slider-active-background-color@blue-
@slider-inactive-background-color@gray-3-
@slider-disabled-opacity@disabled-opacity-
@slider-bar-height2px-
@slider-button-width24px-
@slider-button-height24px-
@slider-button-border-radius50%-
@slider-button-background-color@white-
@slider-button-box-shadow0 1px 2px rgba(0, 0, 0, 0.5)-

Slider 滑块 - 图1