当前位置: 首页 > backend >正文

vue3 定时器-定义全局方法 vue+ts

1.创建ts文件

路径:src/utils/timer.ts

完整代码:


import { onUnmounted } from 'vue'type TimerCallback = (...args: any[]) => voidexport function useGlobalTimer() {const timers: Map<number, NodeJS.Timeout> = new Map()// 创建定时器const setInterval = (callback: TimerCallback,delay: number,...args: any[]): number => {const timerId = window.setInterval(() => callback(...args), delay)timers.set(timerId, timerId)return timerId}// 清除单个定时器const clearInterval = (timerId: number) => {window.clearInterval(timerId)timers.delete(timerId)}// 清除所有定时器const clearAll = () => {timers.forEach((timer) => {window.clearInterval(timer)})timers.clear()}// 组件卸载时自动清理onUnmounted(clearAll)return {setInterval,clearInterval,clearAll}
}

2.挂载到全局属性

路径:src/main.ts

完整代码:

import { createApp } from 'vue'
import App from './App.vue'
import { useGlobalTimer } from './utils/timer'const app = createApp(App)// 挂载到全局属性
app.config.globalProperties.$timer = useGlobalTimer()app.mount('#app')

3.使用方式:

引入全局方法:

import {getCurrentInstance } from 'vue'

const { proxy } = getCurrentInstance()!

使用:

创建定时器:

proxy!.$timer.setInterval(() => { // 需要定时循环的内容 // }, 时间);

 清除定时器:

proxy!.$timer.clearInterval(timerId)

完整代码:

<template></template><script setup lang="ts" name="index">
import {ref, onMounted, onUnmounted, getCurrentInstance} from 'vue';
const {proxy} = getCurrentInstance()!
let timerId: numberonMounted(() => {
//创建定时器timerId = proxy!.$timer.setInterval(() => {//循环内容}, //循环时间);
});
onUnmounted(() => {
//清除定时器proxy!.$timer.clearInterval(timerId)
})
</script>
<style scoped lang="scss"></style>

http://www.xdnf.cn/news/13087.html

相关文章:

  • 人工智能--安全大模型训练计划:基于Fine-tuning + LLM Agent
  • pm2部署Nuxt项目!
  • 开放词汇检测分割YOLOE从pytorch到caffe
  • Clean Code 学习总结01 - 物理设计与命名艺术
  • [Java 基础]String 类
  • MCP和Function Calling
  • OpenCV CUDA模块光流计算-----实现Farneback光流算法的类cv::cuda::FarnebackOpticalFlow
  • Spring Boot 与 Kafka 的深度集成实践(二)
  • Flink 系列之二十二 - 高级概念 - 保存点
  • Linux命令cat /proc/net/snmp查看网络协议层面统计信息
  • 项目管理进阶:解析112页IPD集成产品开发高层培训【附全文阅读】
  • 秋叶包ComfyUI 新手入门攻略及实战指南
  • 11_数据表示与特征工程
  • 华为OD机试-最短木板长度-二分法(A卷,100分)
  • .Net 优秀框架 ABP全面详解
  • 推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材)
  • 第三章:局域网
  • FDA方向图的matlab仿真实现
  • 河北对口计算机高考MySQL笔记(完结版)(2026高考)持续更新~~~~
  • 【Elasticsearch基础】Elasticsearch批量操作(Bulk API)深度解析与实践指南
  • RocketMQ 客户端负载均衡机制详解及最佳实践
  • FFmpeg介绍
  • AI-Python机器学习与深度学习实践技术应用
  • 苹果端Cursor免费额度与模型受限终极解决方案
  • 【Elasticsearch】一个图书馆的案例解释 Elasticsearch
  • Pandas 可视化集成:数据科学家的高效绘图指南
  • 协议转换利器,profinet转ethercat网关的两大派系,各有千秋
  • C#中清空DataGridView的方法
  • RKNN开发环境搭建2-RKNN Model Zoo 环境搭建
  • DAY 26 函数专题1:函数定义与参数