img

js 任务队列函数

2024-01-24 0条评论 321次阅读 JavaScript


/**
 * 表示一个函数队列, 按照指定的间隔顺序执行函数。
 */
export class FunctionQueue {
    /**
     * 创建 FunctionQueue 的实例。
     * @param {number} [interval] - 函数执行的间隔时间(毫秒)。默认为 500 毫秒。
     */
    constructor(interval = 500) {
        /**
         * 函数队列, 存储待执行的函数。
         * @type {Function[]}
         */
        this.queue = []

        /**
         * setInterval 函数的计时器标识。
         * @type {number|null}
         */
        this.timer = null

        /**
         * 函数执行的间隔时间(毫秒)。
         * @type {number}
         */
        this.interval = interval

        /**
         * 标识是否正在执行函数。
         * @type {boolean}
         */
        this.isExecuting = false
    }

    /**
     * 将函数添加到队列中, 并立即触发执行。
     * @param {Function} callback - 要添加到队列中的函数。
     */
    addToQueue(callback) {
        this.queue.push(callback)
        if (!this.isExecuting)
            this.executeNext()
    }

    /**
     * 执行队列中的下一个函数。
     * @private
     */
    async executeNext() {
        if (this.isExecuting || this.queue.length === 0)
            return

        this.isExecuting = true
        const callback = this.queue.shift()
        try {
            await callback()
        }
        catch (error) {
            console.error('执行函数时发生错误:', error)
        }
        this.isExecuting = false

        if (this.queue.length > 0) {
            setTimeout(() => {
                this.executeNext()
            }, this.interval)
        }
    }
}

使用:

import { FunctionQueue } from '@/utils'
const pushMessageQueue = new FunctionQueue(3000) // 3000ms内只执行一次

const messageList = [
    {id:1, name: '消息1'},
    {id:2, name: '消息2'},
    {id:3, name: '消息3'},
    {id:4, name: '消息4'},
    {id:5, name: '消息5'},
]
messageList.forEach((message) => {
    pushMessageQueue.addToQueue(() => {
        messageListVal.push(message)
        console.log(`=====>messageListVal`,messageListVal)
    })
})

这样每三秒push一条数据了

QQ录屏20240124200938 _2_.gif

💬 COMMENT


🦄 支持markdown语法

👋友