页面滚动事件与节流

本文探讨了函数节流在处理页面滚动事件中的应用。由于滚动事件频繁触发,使用节流技术能有效提高性能。示例代码展示了如何实现监听页面滚动到底部的节流处理。

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

函数节流(Throttling)

函数节流应用的实际场景,多数在监听页面元素滚动事件的时候会用到。因为滚动事件,是一个高频触发的事件。以下是监听页面元素滚动到底部的示例代码:

// 简单的节流函数
function throttle(func, wait, mustRun) {
    var timeout,
        startTime = new Date();

    return function() {
        var context = this,
            args = arguments,
            curTime = new Date();

        clearTimeout(timeout);
        // 如果达到了规定的触发时间间隔,触发 handler
        if (curTime - startTime >= mustRun) {
            func.apply(context, args);
            startTime = curTime;
            // 没达到触发间隔,重新设定定时器
        } else {
            timeout = setTimeout(func, wait);
        }
    };
};

// 实际想绑定在 scroll 事件上的 handler
function realFunc() {
    //判断是否滚动到页面最底部
    var scrollTop = Math.ceil($(this).scrollTop());  
    var scrollHeight = $(document).height();  
    var windowHeight = $(this).height();
    if (scrollTop + windowHeight >= scrollHeight) { 
        $("script:first").before("<p>Lorem ip.</p>")
    }
}

// 采用了节流函数
$(window).scroll(throttle(realFunc, 500, 1000))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值