import{o as a,a as t,y as n}from"./vue-libs.b44bc779.js";const e={class:"van-doc-markdown-body"},l=n(`

Slider

Intro

Used to select a value within a given range.

Install

Register component globally via app.use, refer to Component Registration for more registration ways.

import { createApp } from 'vue';
import { Slider } from 'vant';

const app = createApp();
app.use(Slider);

Usage

Basic Usage

<van-slider v-model="value" @change="onChange" />
import { ref } from 'vue';
import { Toast } from 'vant';

export default {
  setup() {
    const value = ref(50);
    const onChange = (value) => Toast('Current value: ' + value);
    return {
      value,
      onChange,
    };
  },
};

Dual thumb

Add range attribute to open dual thumb mode.

<van-slider v-model="value" range @change="onChange" />
import { ref } from 'vue';
import { Toast } from 'vant';

export default {
  setup() {
    // value must be an Array
    const value = ref([10, 50]);
    const onChange = (value) => Toast('Current value: ' + value);
    return {
      value,
      onChange,
    };
  },
};

Range

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

Disabled

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

Step size

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

Custom style

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

Custom button

<van-slider v-model="value" active-color="#ee0a24">
  <template #button>
    <div class="custom-button">{{ value }}</div>
  </template>
</van-slider>

<style>
  .custom-button {
    width: 26px;
    color: #fff;
    font-size: 10px;
    line-height: 18px;
    text-align: center;
    background-color: #ee0a24;
    border-radius: 100px;
  }
</style>

Vertical

<div :style="{ height: '150px' }">
  <van-slider v-model="value" vertical @change="onChange" />
  <van-slider
    v-model="value2"
    range
    vertical
    style="margin-left: 100px;"
    @change="onChange"
  />
</div>
import { ref } from 'vue';
import { Toast } from 'vant';

export default {
  setup() {
    const value = ref(50);
    const value2 = ref([10, 50]);
    const onChange = (value) => Toast('Current value: ' + value);
    return {
      value,
      value2,
      onChange,
    };
  },
};

API

Props

AttributeDescriptionTypeDefault
v-modelCurrent valuenumber | [number, number]0
maxMax valuenumber | string100
minMin valuenumber | string0
stepStep sizenumber | string1
bar-heightHeight of barnumber | string2px
button-sizeButton sizenumber | string24px
active-colorActive color of barstring#1989fa
inactive-colorInactive color of barstring#e5e5e5
rangeWhether to enable dual thumb modebooleanfalse
reverse v3.2.1Whether to reverse sliderfalse
disabledWhether to disable sliderbooleanfalse
readonly v3.0.5Whether to be readonlybooleanfalse
verticalWhether to display slider verticallybooleanfalse

Events

EventDescriptionArguments
update:model-valueEmitted when value is changingvalue: number
changeEmitted after value changedvalue: number
drag-startEmitted when start draggingevent: TouchEvent
drag-endEmitted when end draggingevent: TouchEvent

Slots

NameDescriptionSlotProps
buttonCustom button{ value: number }
left-button v3.1.3Custom left button in range mode{ value: number }
right-button v3.1.3Custom right button in range mode{ value: number }

Types

The component exports the following type definitions:

import type { SliderProps } from 'vant';

Theming

CSS Variables

The component provides the following CSS variables, which can be used to customize styles. Please refer to ConfigProvider component.

NameDefault ValueDescription
--van-slider-active-background-colorvar(--van-primary-color)-
--van-slider-inactive-background-colorvar(--van-gray-3)-
--van-slider-disabled-opacityvar(--van-disabled-opacity)-
--van-slider-bar-height2px-
--van-slider-button-width24px-
--van-slider-button-height24px-
--van-slider-button-border-radius50%-
--van-slider-button-background-colorvar(--van-white)-
--van-slider-button-box-shadow0 1px 2px rgba(0, 0, 0, 0.5)-
`,19),d=[l],i={__name:"README",setup(p,{expose:s}){return s({frontmatter:{}}),(c,o)=>(a(),t("div",e,d))}};export{i as default};