vue3倒计时组件,增加了时间校对

本文介绍了如何使用Vue.js编写一个可配置总时长和间隔的倒计时组件,包括计数逻辑、格式化时间和时间间隔控制,以及与父组件的交互方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<template>
    <div class="countdown-box">
        <span>{
   
   {
   
    formatTime }}</span>
    </div>
</template>

<script lang="ts" setup>

import {
   
    ref, onMounted, onBeforeUnmount, watch } from 'vue';
let formatTime = ref(''); //格式化后的时间

const props = defineProps({
   
   
    totalTime: Number, //总时长 -1未开始 0已结束
    interval: {
   
    //时间间隔
        type: Number,
        default: 1000
    },
})


watch(() => props.totalTime, (newVal, oldVal) => {
   
   
    totalTime = newVal;
    stopCountDown()
    startCountDown()

})


//格式化
/**
 * t: 时间
 * type: 显示类型; 0: :; 1: 小时分钟秒
*/
const secondToTimeStr = (t: number, type: any) => {
   
   
    let timeStr1 = '', timeStr2 = '', timeStr3 = '';
    if (type == 0)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值