js实现页面防抖动

本文介绍了一个用于优化事件处理函数的防抖技术实现方法。通过使用debounce函数包装事件回调,可以确保即使用户短时间内多次触发同一事件(如滚动事件),也只执行最后一次事件处理逻辑,从而有效减少不必要的操作并提升性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:针对频繁触发scoll resize绑定的事件函数,有可能短时间多次触发时事件,影响性能

思路:多个函数调用合成一次,给定时间后仅调用最后一次

// 包装事件的debounce函数

function debounce(func, delay){

    let timer = null;    

    return function(){

         let context = this; // 通过 ‘this’ 和 ‘arguments’ 获取函数的作用域和变量

        let args = arguments; 

        clearTimeout(timer);

        timer = setTimeout(function(){

                func().apply(context, args);

        }, delay)

    }

}

// 当用户滚动时被调用的函数

function foo(){

    cosnole.log("todo somethind");

 }

// 元素绑定scoll事件,触发包装函数debounce

let elem = document.getElementById('container');

elem.addEventListener('scroll', debounce(foo, 2000));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值