TimePicker 组件 #
时间选择器。
何时使用 #
当用户需要输入一个时间,可以点击标准输入框,弹出面板进行选择
基本用法 #
basic
default open
disabled
<template>
  <div class="mb-2">
    <div class="mb-0">basic</div>
    <d-time-picker v-model="time01" placeholder="请选择时间" />
  </div>
  <div class="mb-2">
    <div class="mb-0">default open</div>
    <d-time-picker v-model="vModelValue" :time-picker-width="300" :autoOpen="true" />
  </div>
  <div class="mb-2">
    <div class="mb-0">disabled</div>
    <d-time-picker v-model="vModelValue" disabled />
  </div>
</template>
<script>
import { ref, defineComponent, nextTick } from 'vue';
export default defineComponent({
  setup(props, ctx) {
    let vModelValue = ref('12:30:40');
    let time01 = ref('');
    return {
      vModelValue,
      time01,
    };
  },
});
</script>
显示代码
复制代码片段
时间区间限制 #
minTime
maxTime
maxTime && minTime
<template>
  <div class="mb-2">
    <div class="mb-0">minTime</div>
    <d-time-picker min-time="01:04:30" />
  </div>
  <div class="mb-2">
    <div class="mb-0">maxTime</div>
    <d-time-picker max-time="22:30:30" v-model="vModelValues" />
  </div>
  <div class="mb-2">
    <div class="mb-0">maxTime && minTime</div>
    <d-time-picker min-time="02:04:40" max-time="22:30:30" />
  </div>
</template>
<script>
import { ref, defineComponent, watch } from 'vue';
export default defineComponent({
  setup(props, ctx) {
    let vModelValues = ref('23:30:20');
    return {
      vModelValues,
    };
  },
});
</script>
显示代码
复制代码片段
格式化 #
hh:mm:ss
mm:HH:ss
hh:mm
MM:ss
<template>
  <div class="mb-2">
    <div class="mb-0">hh:mm:ss</div>
    <d-time-picker min-time="01:04:30" />
  </div>
  <div class="mb-2">
    <div class="mb-0">mm:HH:ss</div>
    <d-time-picker class="mb-0" format="mm:HH:ss" v-model="vModelValueFirst" />
    当前选中时间:<button>{{ vModelValueFirst }}</button>
  </div>
  <div class="mb-2">
    <div class="mb-0">hh:mm</div>
    <d-time-picker class="mb-0" format="hh:mm" v-model="hhmm" />
    当前选中时间:<button>{{ hhmm }}</button>
  </div>
  <div class="mb-2">
    <div class="mb-0">MM:ss</div>
    <d-time-picker class="mb-0" format="MM:ss" v-model="mmss" />
    当前选中时间:<button>{{ mmss }}</button>
  </div>
</template>
<script>
import { ref, defineComponent, watch } from 'vue';
export default defineComponent({
  setup(props, ctx) {
    let vModelValueFirst = ref('23:10:20');
    let hhmm = ref('11:12:34');
    let mmss = ref('23:10:20');
    watch(vModelValueFirst, (newValue, oldValue) => {
      console.log(newValue, oldValue);
    });
    return {
      vModelValueFirst,
      mmss,
      hhmm,
    };
  },
});
</script>
显示代码
复制代码片段
传入模板 #
自定义 customViewTemplate
<template>
  <div>
    <div class="mb-0">自定义 customViewTemplate</div>
    <d-time-picker ref="slotDemo">
      <template v-slot:customViewTemplate>
        <div class="slot-box">
          <div class="slot-bottom" @click="chooseNowFun">choose now</div>
          <div class="slot-bottom" @click="chooseTime">choose 23:00</div>
        </div>
      </template>
    </d-time-picker>
  </div>
</template>
<script>
import { ref, defineComponent, nextTick } from 'vue';
export default defineComponent({
  setup(props, ctx) {
    let slotDemo = ref(null);
    const chooseTime = () => {
      let timeObj = {
        time: '23',
        type: 'mm',
      };
      slotDemo.value.chooseTime(timeObj);
    };
    // 插槽内方法  --  选择当前时间
    const chooseNowFun = () => {
      let date = new Date();
      let hour = date.getHours() > 9 ? date.getHours() : '0' + date.getHours();
      let minute = date.getMinutes() > 9 ? date.getMinutes() : '0' + date.getMinutes();
      let second = date.getSeconds() > 9 ? date.getSeconds() : '0' + date.getSeconds();
      let timeObj = {
        time: hour + ':' + minute + ':' + second,
      };
      slotDemo.value.chooseTime(timeObj);
    };
    return {
      chooseNowFun,
      chooseTime,
      slotDemo,
    };
  },
});
</script>
<style>
.slot-box {
  overflow: hidden;
  height: 100%;
}
.slot-bottom {
  font-size: 14px;
  cursor: pointer;
}
.slot-bottom:hover {
  color: #7693f5;
  text-decoration: underline;
}
</style>
显示代码
复制代码片段
获取数据方式 #
selectedTimeChange
v-model
<template>
  <div class="mb-2">
    <div class="mb-0">selectedTimeChange</div>
    <d-time-picker class="mb-0" @change="selectedTimeChange" />
    当前选中时间:<button @click="getNewTimeFun">{{ time1 }}</button>
  </div>
  <div class="mb-2">
    <div class="mb-0">v-model</div>
    <d-time-picker class="mb-0" v-model="time2" />
    当前选中时间:<button @click="getNewTimeFun">{{ time2 }}</button>
  </div>
</template>
<script>
import { ref, defineComponent, nextTick } from 'vue';
export default defineComponent({
  setup(props, ctx) {
    let time1 = ref('00:00:00');
    let time2 = ref('00:00:00');
    // 返回选中的时间
    const selectedTimeChange = (timeValue) => {
      time1.value = timeValue;
    };
    return {
      selectedTimeChange,
      time1,
      time2,
    };
  },
});
</script>
显示代码
复制代码片段
TimePicker 参数 #
| 参数 | 类型 | 默认 | 说明 | 跳转 Demo | 
|---|---|---|---|---|
| disabled | boolean | false | 可选,禁用选择 | 基本用法 | 
| time-picker-width | number | --- | 可选,下拉框的宽度 | 基本用法 | 
| auto-open | boolean | false | 可选,初始化是否直接展开 | 基本用法 | 
| format | string | 'hh:mm:ss' | 可选,传入格式化,控制时间格式 | 格式化 | 
| min-time | string | '00:00:00' | 可选,限制最小可选时间 | 格式化 | 
| max-time | string | '23:59:59' | 可选,限制最大可选时间 | 格式化 | 
| custom-view-template | TemplateRef | -- | 可选,自定义快捷设置时间或自定义操作区内容 | 传入模板 | 
| show-animation | boolean | true | 可选,是否开启动画 | |
| show-glow-style | boolean | true | 可选,是否显示悬浮发光效果 | 
TimePicker 事件 #
| 事件 | 类型 | 说明 | 跳转 Demo | 
|---|---|---|---|
| change | EventEmitter | 可选,确定的时候会发出新激活的子项的数据 | 基本用法 | 
