Vue3+ElementPlus倒计时示例

  • 按钮文字默认显示"开始倒计时"
  • 当点击按钮时,显示正在倒计时(倒计时数字)
  • 倒计时结束按钮显示"开始倒计时"

倒计时逻辑 Hooks 函数

hooks/useCountDown.js

javascript 复制代码
/**
 * hooks函数:函数是用于封装和复用组件逻辑的一种机制
 * 定义:Hooks 是一种在不使用类组件的情况下复用状态逻辑的方法
 * 目的:将组件中的逻辑抽取出来,形成可复用的函数
 * 特点:遵循 Composition API 的思想,使逻辑组织更加灵活
 * 命名规范:通常以 use 开头命名 Hook 函数,如 useCounter、useFetch 等
 */
import {ref, watch} from "vue";

// 封装并导出倒计时函数
export function useCountDown(num = 60) {
  // 倒计时剩余秒数
  const count = ref(num);
  // 是否倒计时中
  const isDown = ref(false);
  // 定时器的 id 编号
  let timerId = null;
  // 开始倒计时函数
  const start = () => {
    if (isDown.value) return; //当前正在倒计时中,则返回
    isDown.value = true;      //设置 isDown 值,表示正在倒计时中
    timerId = setInterval(() => {
      count.value--;
    }, 1000);
  }
  // 使用 watch 监听 count 值,当 count 值变为 0 时,停止计时器
  watch(count, (newCount) => {
    if (newCount <= 0) {
      clearInterval(timerId); //清除计时器
      count.value = num;      //重置 count 值
      isDown.value = false;   //重置 isDown 值
    }
  })

  return {
    count,
    isDown,
    start
  }
}

页面按钮

xxx/index.vue

html 复制代码
<template>
  <el-button type="primary" @click="countDownFn">
    <span v-if="isDown">正在倒计时({{ count }})</span>
    <span v-else>开始倒计时</span>
  </el-button>
</template>

<script setup>
// 导入 hooks 函数
import { useCountDown } from "@/hooks"
// 调用 useCountDown 函数,得到 count计数, isDown是否开始, start 函数
const { count, isDown, start } = useCountDown(10)

// 倒计时
const countDownFn = () => {
  start()
}
</script>

<style lang="scss" scoped>
</style>
相关推荐
Summer不秃20 分钟前
使用 SnapDOM + jsPDF 生成高质量 PDF (含多页分页, 附源码)
前端·javascript·vue.js·pdf·node.js
灯把黑夜烧了一个洞1 小时前
2026年跨年倒计时网页版
javascript·css·html·2026跨年代码·新年代码
仰望.1 小时前
vxe-table 如何实现分页勾选复选框功能,分页后还能支持多选的选中状态
前端·vue.js·vxe-table
前端小咸鱼一条1 小时前
Redux
react.js·前端框架
zhenryx1 小时前
React Native 横向滚动指示器组件库(淘宝|京东...&旧版|新版)
javascript·react native·react.js
POLITE31 小时前
Leetcode 54.螺旋矩阵 JavaScript (Day 8)
javascript·leetcode·矩阵
licongmingli1 小时前
vue2 基于虚拟dom的下拉选择框,保证大数据不卡顿,仿antd功能和样式
大数据·前端·javascript·vue.js·anti-design-vue
黎明初时1 小时前
react基础框架搭建4-tailwindcss配置:react+router+redux+axios+Tailwind+webpack
前端·react.js·webpack·前端框架
小沐°1 小时前
vue3-父子组件通信
前端·javascript·vue.js
码界奇点1 小时前
基于逆向工程技术的Claude Code智能Agent系统分析与重构研究
javascript·ai·重构·毕业设计·源代码管理