vant4如何封装日期段选择器
TimeRangePickerTypes.ts
import { ExtractPropTypes, PropType } from 'vue'
import dayjs from 'dayjs'
export const props = {
/** 窗口是否显示 */
visible: {
type: Boolean,
default: false
},
/** 时间段,[HH:mm,HH:mm] */
times: {
type: Array as PropType,
default: () => [dayjs().format('HH-mm'), dayjs().format('HH-mm')]
},
/** 中间分隔符 */
apart: {
type: String,
default: '~'
},
/** 最大时间 */
maxTime: {
type: Number,
default: 23
},
/** 最小时间 */
minTime: {
type: Number,
default: 1
},
/** 最大分钟数 */
maxMinute: {
type: Number,
default: 59
},
/** 最小分钟数 */
minMinute: {
type: Number,
default: 1
}
}
export type Props = ExtractPropTypes
export interface timeResult {
/** 开始时间 */
startTime: string
/** 开始分钟 */
startMinute: string
/** 结束时间 */
endTime: string
/** 结束分钟 */
endMinute: string
}TimeRangePicker.vue
useColumns.ts
import { computed, ref } from 'vue'
import { PickerOption } from 'vant'
import { Props } from '../types'
export function useColumns(props: Props) {
/** 时段 */
const times = computed(() => {
const result: PickerOption[] = []
for (let i = props.minTime; i <= props.maxTime; i++) {
const v = `${i}`.padStart(2, '0')
result.push({
text: v,
value: v
})
}
return result
})
/** 分钟 */
const minutes = computed(() => {
const result: PickerOption[] = []
for (let i = props.minMinute; i <= props.maxMinute; i++) {
const v = `${i}`.padStart(2, '0')
result.push({
text: v,
value: v
})
}
return result
})
/** 显示列 */
const columns = ref([
times.value,
minutes.value,
[{ text: props.apart, value: props.apart }],
times.value,
minutes.value
])
return {
columns
}
}使用
选择日期
效果

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: hlamps#outlook.com (#换成@)。