Skip to content

倒计时 Countdown

倒计时

何时使用

  • 当要展示倒计时时

基本使用

format: MM月 DD天 HH:mm:ss


Countdown 1年
00月 00天 00:00:00
Show Code
vue
<script setup lang="ts">
function onFinish () {
  console.log('countdown finished')
}
</script>
<template>
  <Countdown
    title="Countdown 1年"
    :value="12 * 30 * 24 * 60 * 60 * 1000"
    :future="false"
    format="MM月 DD天 HH:mm:ss"
    @finish="onFinish"
  />
</template>

毫秒倒计时

format: Y 年 M 月 D 天 H 时 m 分 s 秒 SSS


Million Seconds
0 年 0 月 0 天 0 时 0 分 0 秒 000 毫秒
Show Code
vue
<template>
  <Countdown
    title="Million Seconds"
    :value="12 * 30 * 24 * 60 * 60 * 1000"
    :future="false"
    format="Y 年 M 月 D 天 H 时 m 分 s 秒 SSS 毫秒"
  />
</template>

随时暂停

Pause at any time
00:00:00:000
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const active = ref(true)
</script>
<template>
  <Space vertical>
    <Switch v-model="active" />
    <Countdown
      :active="active"
      title="Pause at any time"
      :value="24 * 60 * 60 * 1000"
      :future="false"
      format="HH:mm:ss:SSS"
    />
  </Space>
</template>

前缀和后缀

2048年 五一 Countdown
There's only0 年 0 月 0 天 0 时 0 分 0 秒 000 毫秒left for the end.
Show Code
vue
<template>
  <Countdown
    :value="2471875200000"
    format="Y 年 M 月 D 天 H 时 m 分 s 秒 SSS 毫秒"
  >
    <template #title>2048年 五一 Countdown</template>
    <template #prefix>There's only</template>
    <template #suffix>left for the end.</template>
  </Countdown>
</template>

自定义样式

2048年 十一 Countdown
0 年 00 月 00 天 00 时 00 分 00 秒 000 毫秒
Show Code
vue
<template>
  <Countdown
    :value="2485094400000"
    format="Y 年 MM 月 DD 天 HH 时 mm 分 ss 秒 SSS 毫秒"
    :title-style="{ fontWeight: 500, fontSize: '18px' }"
    :value-style="{ fontWeight: 600, color: '#1677ff' }"
  >
    <template #title>2048年 十一 Countdown</template>
  </Countdown>
</template>

倒计时已完成

00:00:00
Finished
Show Code
vue
<template>
  <Space gap="small" vertical>
    <Countdown />
    <Countdown finish="Finished" />
  </Space>
</template>

重置倒计时

Reset
00:00:00:000
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const resetActive = ref(true)
const countdownRef = ref()
function onReset() {
  countdownRef.value.reset()
}
</script>
<template>
  <Space vertical>
    <Space align="center">
      <Switch v-model="resetActive" />
      <Button type="primary" @click="onReset">Reset</Button>
    </Space>
    <Countdown
      ref="countdownRef"
      :active="resetActive"
      :value="24 * 60 * 60 * 1000"
      :future="false"
      format="HH:mm:ss:SSS"
    />
  </Space>
</template>

APIs

Countdown

参数说明类型默认值
title倒计时标题string | slotundefined
titleStyle设置标题的样式CSSProperties{}
prefix倒计时的前缀string | slotundefined
suffix倒计时的后缀string | slotundefined
finish倒计时完成后的展示文本string | slotundefined
futurevalue 是否为未来某时刻的时间戳;为 false 表示相对剩余时间戳booleantrue
format倒计时展示格式,(Y/YY:年,M/MM:月,D/DD:日,H/HH:时,m/mm:分钟,s/ss:秒,SSS:毫秒)string'HH:mm:ss'
value倒计时数值,支持设置未来某时刻的时间戳或相对剩余时间,单位 msnumber0
valueStyle设置倒计时的样式CSSProperties{}
active是否处于计时状态,仅当 future: false 时生效booleantrue

Slots

名称说明类型
title自定义倒计时标题v-slot:title
prefix自定义倒计时的前缀v-slot:prefix
suffix自定义倒计时的后缀v-slot:suffix
finish自定义完成后的展示文本v-slot:finish

Methods

名称说明类型
reset重置倒计时() => void

Events

名称说明类型
finish倒计时结束的回调() => void

Released under the MIT License.