防抖debounce函数的基本使用

前言

防抖和节流函数目前已经是前端实际开发中两个非常重要的函数,也是面试经常被问到的面试题,我们会一起来学习防抖和节流函数。


一、认识防抖debounce函数

  • 我们用一副图来理解一下它的过程:
    在这里插入图片描述

二、使用步骤

1.代码演示

代码如下(示例):

index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <input type="text">
    <script src="./debounce的基本实现/01_debounce.js"></script>
    <script>
        const inputEl = document.querySelector("input")
        const inputChangeg = function (event) {
            console.log("发送了网络请求!",this,event);
        }
        // 防抖处理:传入两个参数,一个执行的函数,一个延迟的事件
        inputEl.oninput = debounce(inputChangeg,2000)
    </script>
</body>
</html>

js代码

//fn 需要执行的函数
// delay: 需要延迟多长时间
function debounce (fn, delay) {
    // 定义一个定时器,保存上一次的定时器(timer是个数字)
    let timer = null
    // 发生事件,真正执行的函数
    const _debounce = function (...args) {
        // 取消上一次的定时器
        if (timer) clearTimeout(timer)
        //settimeout 会返回一个返回值timer
        // 延迟执行
        timer = setTimeout(() => {
            // 外部传入的真正执行的函数
            fn.apply(this,args)//注意这里有this的绑定与参数的传递
        }, delay);
    }
    return _debounce
}

总结

coderwhy老师讲的debounce的基本使用,注意这里面有this的绑定与参数的传递。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值