滑动输入条 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 | 是否启用垂直模式 | boolean | false |
min | 最小值 | number | 0 |
max | 最大值 | number | 100 |
disabled | 是否禁用 | boolean | false |
range | 是否使用双滑块模式 | boolean | false |
step | 步长,取值必须大于 0 ,并且可被 (max - min) 整除 | number | 1 |
formatTooltip | Slider 会把当前值传给 formatTooltip ,并在 Tooltip 中显示 formatTooltip 的返回值 | (value: number) => string | number | (value: number) => value |
tooltip | 是否展示 Tooltip | boolean | true |
value v-model | 设置当前取值,当 range 为 false 时,使用 number ,否则用 [number, number] | number | number[] | 0 |
Events
名称 | 说明 | 类型 |
---|---|---|
change | 当前取值变化后的回调 | (value: number | number[]) => void |