JS定时任务封装(支持精确倒计时)

TypeScript 复制代码
/***
 * callback 定时任务回调函数,
 * time 任务执行的间隔时间,
 * config.accurate 是否是精准的定时任务,如果是,会自动修正定时器偏差。
 */
export default function (
    callback: () => void, 
    time: number, 
    config?: {
        accurate: boolean // 是否是精准的定时任务,如果是,会自动修正定时器偏差。
    }
) {
    let task: any = null

    const record = {
        startTime: 0,
        runTime: 0,
        offsetTime: 0
    }

    const run = () => {
        if (config?.accurate) {
            record.startTime = new Date().getTime()
        }
        task = setTimeout(() => {
            if (config?.accurate) {
                record.runTime = new Date().getTime()
                record.offsetTime = time - (record.runTime - record.startTime)
            } else {
                record.offsetTime = 0
            }
            // 必须先run,再执行callback,防止在callback中调用clearTask方法
            run()
            callback()
        }, time + record.offsetTime)
    }

    /**
     * 清除定时任务
     */
    const clearTask = () => {
        clearTimeout(task)
        task = null
    }

    /**
     * 启动定时任务
     * @param immediate 是否立即运行
     */
    const startTask = (immediate?: boolean) => {
        if (immediate) {
            callback()
        }
        clearTask()
        run();
    }

    return {
        clearTask,
        startTask
    }
}

使用、控制都很方便:

TypeScript 复制代码
// 初始化
const { clearTask, startTask } = useInterval(() => {
    // do something....

}, 1000)

// 启动
startTask()


// 清除
clearTask()


//重新启动
clearTask()
startTask()
相关推荐
IT_陈寒6 分钟前
React性能翻倍!90%开发者忽略的5个Hooks最佳实践
前端·人工智能·后端
亿元程序员13 分钟前
光图片就300多M,微信小游戏给再大的分包也难啊!
前端
蓝天智能22 分钟前
立体字型效果的Qt QSS实现
开发语言·qt
艾莉丝努力练剑23 分钟前
【C++:哈希表】从哈希冲突到负载因子:熟悉哈希表的核心机制
开发语言·c++·stl·散列表·哈希表·哈希·映射
虾..27 分钟前
C++ 特殊类的设计
开发语言·c++
中工钱袋28 分钟前
前端请求到底是从哪里发出去的?
前端
拾忆,想起1 小时前
Dubbo超时问题排查与调优指南:从根因到解决方案
服务器·开发语言·网络·微服务·架构·php·dubbo
7ioik2 小时前
什么是线程池?线程池的作用?线程池的四种创建方法?
java·开发语言·spring
寻星探路2 小时前
JavaSE重点总结后篇
java·开发语言·算法
Charles_go3 小时前
C#中级8、什么是缓存
开发语言·缓存·c#