JS定时任务

1、js定时任务

描述:基于javascript、利用window.requestAnimationFrame实现的定时任务

/**
 * @desc: 定时任务
 * @author wangheng
 * @param pool: {} 存放所有任务的对象
 * @param taskId // 当前执行的requestAnimationFrame返回的ID
 * @function add 添加任务方法  remove 移除任务方法 start 开始方法  stop 停止定时任务方法
 * @date: 2019-07-02
 * @VERSION: 1.0
 */
const defaultInterval = 30000; // 默认时间间隔,单位:毫秒
const task = {
    defaultPool: {}, // 永远不会被清除的任务池
    pool: {},
    taskId: 0,
    addDefault: (name, fn, interval) => { // 调用此方法加入的任务执行start时候不会被清除
        task.defaultPool[name] = {
            name,
            fn,
            interval: interval || defaultInterval,
            excuteTime: 0,
        };
    },
    add: (name, fn, interval) => { // 调用此方法加入的任务执行start时候会被清除
        task.pool[name] = {
            name,
            fn,
            interval: interval || defaultInterval,
        };
    },
    remove: (name) => { // 根据任务名移除某个任务
        delete task.pool[name];
    },
    clearPool: () => { // 清空任务池
        task.pool = {};
    },
    excute: () => { // 执行定时任务方法
        task.taskId = window.requestAnimationFrame((ms) => {
            const usePool = { ...task.pool, ...task.defaultPool };
            Object.keys(usePool).forEach((key) => {
                const obj = usePool[key];
                if (ms - obj.excuteTime >= obj.interval) {
                    obj.fn();
                    obj.excuteTime = ms;
                }
            });
            task.excute();
        });
    },
    start: () => { // 任务开启方法
        task.pool = {};
        task.stop();
        window.requestAnimationFrame((ms) => {
            Object.keys(task.pool).forEach((key) => {
                task.pool[key].fn(); // 启动后先执行一次
                task.pool[key].excuteTime = ms;
            });
            task.excute();
        });
    },
    stop: () => { // 停止定时任务
        window.cancelAnimationFrame(task.taskId);
    },
};

调用方法:

function taskOne() {
	console.log('定时任务1');
}
task.start();
task.add('定时任务1', taskOne(),30000);
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值