函数节流和防抖

"防抖"

首先,先去解释一下什么叫做防抖, 在事件被触发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;
            }
        };
    }
相关推荐
一袋米扛几楼987 分钟前
【网络安全】SIEM -Security Information and Event Management 工具是什么?
前端·安全·web安全
小陈工18 分钟前
2026年4月7日技术资讯洞察:下一代数据库融合、AI基础设施竞赛与异步编程实战
开发语言·前端·数据库·人工智能·python
Cobyte27 分钟前
3.响应式系统基础:从发布订阅模式的角度理解 Vue2 的数据响应式原理
前端·javascript·vue.js
竹林81831 分钟前
从零到一:在React前端中集成The Graph查询Uniswap V3池数据实战
前端·javascript
Mintopia38 分钟前
别再迷信"优化":大多数性能问题根本不在代码里
前端
倾颜38 分钟前
接入 MCP,不一定要先平台化:一次 AI Runtime 的实战取舍
前端·后端·mcp
军军君0141 分钟前
Three.js基础功能学习十八:智能黑板实现实例五
前端·javascript·vue.js·3d·typescript·前端框架·threejs
恋猫de小郭41 分钟前
Android 上为什么主题字体对 Flutter 不生效,对 Compose 生效?Flutter 中文字体问题修复
android·前端·flutter
Moment42 分钟前
AI全栈入门指南:一文搞清楚NestJs 中的 Controller 和路由
前端·javascript·后端
禅思院43 分钟前
前端架构演进:基于AST的常量模块自动化迁移实践
前端·vue.js·前端框架