Skip to content

滑动输入条 Slider

滑动型输入器,展示当前值和可选范围

何时使用

  • 当用户需要在数值区间/自定义区间内进行选择时

基本使用

NaN
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const singleValue = ref(20)
watchEffect(() => {
  console.log('singleValue', singleValue.value)
})
function onChange(value: number | number[]) {
  console.log('change', value)
}
</script>
<template>
  <Slider v-model:value="singleValue" @change="onChange" />
</template>

禁用

NaN
NaN
NaN
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const singleValue = ref(20)
const doubleValue = ref([20, 80])
</script>
<template>
  <Flex vertical gap="large">
    <Slider v-model:value="singleValue" disabled />
    <Slider v-model:value="doubleValue" range disabled />
  </Flex>
</template>

双滑块

NaN
NaN
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const doubleValue = ref([20, 80])
watchEffect(() => {
  console.log('doubleValue', doubleValue.value)
})
function onChange(value: number | number[]) {
  console.log('change', value)
}
</script>
<template>
  <Slider range v-model:value="doubleValue" @change="onChange" />
</template>

自定义最大最小值

NaN
NaN
NaN
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const singleCustomValue = ref(0)
const doubleCustomValue = ref([-5, 5])
watchEffect(() => {
  console.log('singleCustomValue', singleCustomValue.value)
})
watchEffect(() => {
  console.log('doubleCustomValue', doubleCustomValue.value)
})
</script>
<template>
  <Flex vertical gap="large">
    <Slider :min="-10" :max="10" v-model:value="singleCustomValue" />
    <Slider :min="-10" :max="10" range v-model:value="doubleCustomValue" />
  </Flex>
</template>

自定义步长

NaN
NaN
NaN
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const singleCustomStepValue = ref(30)
const doubleCustomStepValue = ref([30, 60])
watchEffect(() => {
  console.log('singleCustomStepValue', singleCustomStepValue.value)
})
watchEffect(() => {
  console.log('doubleCustomStepValue', doubleCustomStepValue.value)
})
</script>
<template>
  <Flex vertical gap="large">
    <Slider :step="5" v-model:value="singleCustomStepValue" />
    <Slider range :step="5" v-model:value="doubleCustomStepValue" />
  </Flex>
</template>

垂直模式

NaN
NaN
NaN
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const singleValue = ref(20)
const doubleValue = ref([20, 80])
watchEffect(() => {
  console.log('singleValue', singleValue.value)
})
watchEffect(() => {
  console.log('doubleValue', doubleValue.value)
})
</script>
<template>
  <Space :gap="36" style="height: 300px">
    <Slider vertical v-model:value="singleValue" />
    <Slider range vertical v-model:value="doubleValue" />
  </Space>
</template>

带输入框的滑块

Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const singleValue = ref(20)
const smallSingleValue = ref(0.5)
watchEffect(() => {
  console.log('singleValue', singleValue.value)
})
watchEffect(() => {
  console.log('smallSingleValue', smallSingleValue.value)
})
</script>
<template>
  <Row :gutter="[24, 16]">
    <Col :span="18">
      <Slider v-model:value="singleValue" />
    </Col>
    <Col :span="6">
      <InputNumber v-model:value="singleValue" :min="0" :max="100" />
    </Col>
    <Col :span="18">
      <Slider v-model:value="smallSingleValue" :min="0" :max="1" :step="0.01" />
    </Col>
    <Col :span="6">
      <InputNumber v-model:value="smallSingleValue" :min="0" :max="1" :step="0.01" />
    </Col>
  </Row>
</template>

格式化 tooltip

NaN%
NaN%
NaN%
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const singleValue = ref(20)
const doubleValue = ref([20, 80])
watchEffect(() => {
  console.log('singleValue', singleValue.value)
})
watchEffect(() => {
  console.log('doubleValue', doubleValue.value)
})
function formatter (value: number) {
  return `${value}%`
}
</script>
<template>
  <Flex vertical gap="large">
    <Slider :format-tooltip="formatter" v-model:value="singleValue" />
    <Slider range :format-tooltip="formatter" v-model:value="doubleValue" />
  </Flex>
</template>

隐藏 tooltip

Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const singleValue = ref(20)
const doubleValue = ref([20, 80])
watchEffect(() => {
  console.log('singleValue', singleValue.value)
})
watchEffect(() => {
  console.log('doubleValue', doubleValue.value)
})
</script>
<template>
  <Flex vertical gap="large">
    <Slider :tooltip="false" v-model:value="singleValue" />
    <Slider range :tooltip="false" v-model:value="doubleValue" />
  </Flex>
</template>

自定义样式

NaN
NaN
NaN
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const singleValue = ref(20)
const doubleValue = ref([20, 80])
const customStyle = {
  '--track-color': '#ffbb96',
  '--track-color-hover': '#d4380d',
  '--handle-color': '#fff2e8',
  '--handle-shadow-color': '#ffbb96',
  '--handle-shadow-color-hover-focus': '#d4380d'
}
const rangeCustomStyle = {
  '--rail-color': 'rgb(219, 219, 223)',
  '--rail-color-hover': 'rgb(199, 199, 203)',
  '--track-color': '#ffbb96',
  '--track-color-hover': '#d4380d',
  '--handle-color': '#fff2e8',
  '--handle-shadow-color': '#ffbb96',
  '--handle-shadow-color-hover-focus': '#d4380d'
}
watchEffect(() => {
  console.log('singleValue', singleValue.value)
})
watchEffect(() => {
  console.log('doubleValue', doubleValue.value)
})
</script>
<template>
  <Flex vertical gap="large">
    <Slider :style="customStyle" v-model:value="singleValue" />
    <Slider :style="rangeCustomStyle" range v-model:value="doubleValue" />
  </Flex>
</template>

APIs

Slider

参数说明类型默认值
width滑动输入条宽度,单位 px,水平模式时生效string | number'100%'
height滑动输入条高度,单位 px,垂直模式时生效string | number'100%'
vertical是否启用垂直模式booleanfalse
min最小值number0
max最大值number100
disabled是否禁用booleanfalse
range是否使用双滑块模式booleanfalse
step步长,取值必须大于 0,并且可被 (max - min) 整除number1
formatTooltipSlider 会把当前值传给 formatTooltip,并在 Tooltip 中显示 formatTooltip 的返回值(value: number) => string | number(value: number) => value
tooltip是否展示 Tooltipbooleantrue
value
v-model
设置当前取值,当 rangefalse 时,使用 number,否则用 [number, number]number | number[]0

Events

名称说明类型
change当前取值变化后的回调(value: number | number[]) => void

Released under the MIT License.