2627函数防抖

请你编写一个函数,接收参数为另一个函数和一个以毫秒为单位的时间 t ,并返回该函数的 函数防抖 后的结果。

函数防抖 方法是一个函数,它的执行被延迟了 t 毫秒,如果在这个时间窗口内再次调用它,它的执行将被取消。你编写的防抖函数也应该接收传递的参数。

例如,假设 t = 50ms ,函数分别在 30ms60ms100ms 时调用。前两个函数调用将被取消,第三个函数调用将在 150ms 执行。如果改为 t = 35ms ,则第一个调用将被取消,第二个调用将在 95ms 执行,第三个调用将在 135ms 执行。

复制代码
var debounce = function(fn, t) {
    let timeId = null; // 用于存储定时器的ID

    // 返回一个新的函数,这个新函数在被调用时会进行防抖处理
    return function(...args) {
        // 如果timeId不为null,说明有一个定时器正在运行,需要取消它
        if (timeId) clearTimeout(timeId);

        // 设置一个新的定时器,t毫秒后执行fn函数,并传入当前的所有参数
        timeId = setTimeout(() => fn(...args), t);
    }
};
  1. 性能考虑 :防抖函数通过取消之前的定时器来确保函数不会在短时间内被多次调用。但是,如果防抖函数的调用非常频繁(比如在一个高速循环中),那么 clearTimeoutsetTimeout 的调用也会成为性能瓶颈。在实际应用中,应该根据具体场景选择合适的防抖策略。

  2. 立即执行与延迟执行 :标准的防抖函数(如您提供的实现)是延迟执行的,即函数只会在最后一次触发后的延迟时间 t 毫秒内没有新触发时才会执行。如果您希望函数在第一次触发时立即执行,并在之后的触发中遵循防抖逻辑,那么您需要对这个实现进行一些修改。

  3. 清除防抖 :在某些情况下,您可能需要在组件卸载或事件监听器移除之前手动清除防抖函数。这通常涉及到保存防抖函数的返回值(即新函数)并在适当的时候调用 clearTimeout 来清除定时器。但是,在大多数情况下,如果组件或事件监听器被正确销毁,那么由它们触发的定时器通常也会被自动清除。

相关推荐
寧笙(Lycode)4 分钟前
OpenTelemetry 入门
前端
猪哥帅过吴彦祖7 分钟前
Flutter 系列教程:列表与网格 - `ListView` 和 `GridView`
前端·flutter·ios
用户352120195607 分钟前
React hooks (useRef)
前端
Mintopia11 分钟前
⚡当 Next.js 遇上实时通信:Socket.io 与 Pusher 双雄传
前端·后端·全栈
tangdou36909865514 分钟前
可怕!我的Nodejs系统因为日志打印了Error 对象就崩溃了😱 Node.js System Crashed Because of Logging
前端·javascript·后端
Takklin17 分钟前
Vue 与 React 应用初始化机制对比 - 前端框架思考笔记
前端·react.js
Mintopia20 分钟前
🎨 数据增强技术在 AIGC 训练中的应用:提升 Web 生成的多样性
前端·javascript·aigc
华仔啊20 分钟前
如何用 Vue3 打造高级音乐播放器?进度条+可视化效果,代码简洁可复用!
前端·css·vue.js
小傅哥21 分钟前
新项目完结,Ai Agent 智能体、拖拉拽编排!
前端·后端
xiaohua0708day24 分钟前
关于解决js中MediaRecorder录制的webm视频没有进度条的问题
javascript·音视频