函数节流和防抖

"防抖"

首先,先去解释一下什么叫做防抖, 在事件被触发n秒后再执行回调,如果在这n秒内又被触发,则重新计时。也就是说 用户触发时间过于频繁,只要最后一次请求的操作就叫做防抖。

javascript 复制代码
	// 函数防抖
	//time秒之后调用,如果频繁触发则重新计时
   <input type="text" />
    <script>
      let input = document.querySelector("input");
      input.onkeydown = debounce(function (e) {
        console.log(e.keyCode);
      }, 1000);

      function debounce(callback, time) {
        //定时器变量
        let timeId = null;

        //返回一个函数
        return function (e) {
          if (timeId !== null) {
            clearTimeout(timeId);
          }
          timeId = setTimeout(() => {
            //执行回调
            callback.call(this, e);
            //重置定时器变量
            timeId = null;
          }, time);
        };
      }

节流

限制函数在规定时间内执行的次数

javascript 复制代码
    //函数节流
    //在wait毫秒内最多执行 callback 一次
    function throttle(callback, wait) {
        //定义开始时间
        let start = 0;
        //返回结果是一个函数
        return function (e) {
            //获取当前的时间戳
            let now = Date.now();
            // let new = +new Date()

            //使用现在的时间戳减去上一次的时间戳
            if (now - start >= wait) {
                callback.call(this, e);
                //start:代表上一次执行的时间
                start = now;
            }
        };
    }
相关推荐
Moment10 小时前
Vibe Coding 时代,到底该选什么样的工具来提升效率❓❓❓
前端·后端·github
IT_陈寒11 小时前
SpringBoot性能飙升200%?这5个隐藏配置你必须知道!
前端·人工智能·后端
小时前端11 小时前
React性能优化的完整方法论,附赠大厂面试通关技巧
前端·react.js
Nicko12 小时前
Jetpack Compose BOM 2026.02.01 解读与升级指南
前端
小蜜蜂dry12 小时前
nestjs学习 - 控制器、提供者、模块
前端·node.js·nestjs
优秀稳妥的JiaJi12 小时前
基于腾讯地图实现电子围栏绘制与校验
前端·vue.js·前端框架
前端开发呀12 小时前
从 qiankun(乾坤) 迁移到 Module Federation(模块联邦),对MF只能说相见恨晚!
前端
Lee川13 小时前
深度解构JavaScript:作用域链与闭包的内存全景图
javascript·面试
没想好d13 小时前
通用管理后台组件库-10-表单组件
前端
恋猫de小郭13 小时前
你用的 Claude 可能是虚假 Claude ,论文数据告诉你,Shadow API 中的欺骗性模型声明
前端·人工智能·ai编程