函数节流和防抖

"防抖"

首先,先去解释一下什么叫做防抖, 在事件被触发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;
            }
        };
    }
相关推荐
Mr Xu_几秒前
前端开发中CSS代码的优化与复用:从公共样式提取到CSS变量的最佳实践
前端·css
低代码布道师22 分钟前
Next.js 16 全栈实战(一):从零打造“教培管家”系统——环境与脚手架搭建
开发语言·javascript·ecmascript
鹏北海-RemHusband37 分钟前
从零到一:基于 micro-app 的企业级微前端模板完整实现指南
前端·微服务·架构
LYFlied37 分钟前
AI大时代下前端跨端解决方案的现状与演进路径
前端·人工智能
光影少年41 分钟前
AI 前端 / 高级前端
前端·人工智能·状态模式
一位搞嵌入式的 genius42 分钟前
深入 JavaScript 函数式编程:从基础到实战(含面试题解析)
前端·javascript·函数式
anOnion1 小时前
构建无障碍组件之Alert Dialog Pattern
前端·html·交互设计
choke2331 小时前
[特殊字符] Python 文件与路径操作
java·前端·javascript
云飞云共享云桌面1 小时前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
Deng9452013141 小时前
Vue + Flask 前后端分离项目实战:从零搭建一个完整博客系统
前端·vue.js·flask