函数节流和防抖

"防抖"

首先,先去解释一下什么叫做防抖, 在事件被触发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;
            }
        };
    }
相关推荐
温宇飞10 分钟前
Web 图形合成技术:Blending 与 Porter-Duff Compositing
前端
小高00714 分钟前
读懂 Tailwind v4:为什么它是现代前端项目的必选项?
前端·javascript·vue.js
boooooooom15 分钟前
computed、watch 与 watchEffect 的使用边界与实战指南
javascript·vue.js
我的golang之路果然有问题16 分钟前
python中 unicorn 热重启问题和 debug 的 json
java·服务器·前端·python·json
SpringLament16 分钟前
从零打造AI智能博客:一个项目带你入门全栈与大模型应用开发
前端·aigc
晴虹17 分钟前
lecen:一个更好的开源可视化系统搭建项目--数据、请求、寄连对象使用--全低代码|所见即所得|利用可视化设计器构建你的应用系统-做一个懂你的人
前端·后端·低代码
MOON404☾18 分钟前
004.漏洞分析与利用
前端·网络·网络安全·系统安全·firefox
kylezhao201922 分钟前
C#根据时间加密和防止反编译
java·前端·c#
愈努力俞幸运34 分钟前
volta教程 下载安装使用
前端
冰暮流星39 分钟前
javascript短路运算
开发语言·前端·javascript