函数节流和防抖

"防抖"

首先,先去解释一下什么叫做防抖, 在事件被触发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;
            }
        };
    }
相关推荐
用户85249507184几秒前
# 大二前端新人的AI初体验:跟着吴恩达学“Vibe Coding”,我如何用提示词“指挥”AI写代码?
前端
bupt_011 分钟前
Hermes深入理解及源码解析(二):Hermes的记忆机制
java·服务器·前端
飘尘3 分钟前
WebAssembly 是什么?它为什么重要?
前端·javascript
情绪总是阴雨天~4 分钟前
大模型 Function Call(函数调用)详解:原理、实践与数据库智能查询 Agent
前端·数据库·人工智能
之歆7 分钟前
DAY_10 JavaScript 深度解析:原型链 · 引用类型 · 内置对象 · 数组方法全攻略(上)
开发语言·javascript·ecmascript
GalenZhang88829 分钟前
OpenClaw (2026.4.x 至 2026.5.12) 升级问题及解决
前端·chrome·openclaw
Ww.xh37 分钟前
鸿蒙Web组件中Hash路由传登录态方案
前端·哈希算法·harmonyos
LCG元1 小时前
STM32实战:基于STM32F103的智慧教室环境监控系统(CO₂+光照+人数统计)
前端·stm32·嵌入式硬件
yqcoder2 小时前
Vue 的心脏:深度解析 Vue 2 vs Vue 3 响应式机制
前端·javascript·vue.js
东方小月2 小时前
Claude Code Skill 完全指南:一个 markdown 文件,就是一个专家分身
前端·后端