防抖使用-js

本文详细介绍了防抖函数在页面大小统计、滚动计算等场景的应用,以及五个关键难点,包括避免立即执行、清除定时、保持执行函数关联、this指向处理和参数传递。通过实例展示了如何使用高阶函数、闭包和作用域链来实现防抖功能。
摘要由CSDN通过智能技术生成

防抖:

应用场景:

1)改变页面大小的统计

2)滚动页面位置的计算

3)输入框连续输入的请求次数的控制

4)防止表单多次提交

防抖函数的5个难点:

 1)如何避免防抖函数的立即执行,即未点击按钮,就调用函数造成输出? --- 高阶函数, 防抖函数返回一个函数,然后被防抖函数《执行函数》放在返回的函数内部;

2)clearTimeout清除定时变量放在设置定时返回变量前面

3)让独立的执行函数产生联系,即不能每次点击的时候都创建timer,清除timer、设置定时,会导致起不到防抖的效果; ---- 使用作用域链/闭包,在return返回的函数《执行函数》外面定义timer变量,使得每次都访问同一个变量timer。

4)this的指向,由于setTimeout回调函数this执行window的原因,运行时候我们需要将this的指向改变为按钮;---- 先将 this保存,然后使用call方法显示改变this的指向;

5)执行函数传入参数的问题 ---- 使用arguments对象进行保存

const btn = document.getElementsByClassName('button')

// 执行函数
function payMoney(){
    console.log('已剁手')
}

// 1、执行函数--高阶函数
function debounce(fn){
    return function(){
        fn()
    }
}
// 2、设置定时
function debounce(fn,delay){
    return function(){
        setTimeout(function(){
            fn()
        },delay)
    }
}

// 清除定时
function debounce(fn, delay){
    return function(){
        clearTimeout(timer)
        timer = setTimeout(function(){
            fn()
        }, delay)
    }
}

// 使用闭包/作用域链来实现清除
function debounce(fn, delay){
    let timer 
    return function(){
        clearTimeout(timer)
        timer = setTimeout(function(){
            fn()
        },delay)
    }
}

// 解决this指向和参数问题
function debounce(fn, delay){
    let timer
    return function(){
        let context = this
        let args = arguments
        clearTimeout(timer)
        timer = setTimeout(function(){
            fn.call(context, args)
        },delay)
    }
}

btn.addEventListener('click', debounce(payMoney, 1000))

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值