【闭包应用】JS:防抖、节流

1、防抖:当进行连续操作时,只执行最后一次的操作。

复制代码
 //防抖的概念是 当进行连续操作时,只执行最后一次的操作。
    function debounce(fn, delayTime) {
      let timeout = null;

      return function () {
        if (timeout) {
          clearTimeout(timeout);
        }

        timeout = setTimeout(() => {
          fn.call(this);
          timeout = null;
        }, delayTime);
      };
    }

    function func() {}

    debounce(func,200)

2、节流:
节流的概念是在一定时间内,用户没有再次进行此操作,在固定时间范围内只让操作一次。简单的说就是此次操作时间和上次操作时间要大于时间差,时间差的值由用户指定。
实现原理:使用闭包创建私有变量,这个私有变量用来记录上次操作的时间,此次操作时间与这个私有变量的差值如果超过已设置的时间范围差值,则进行次函数调用,否则不进行调用此函数。

复制代码
   function func(){

    }

 
    /**
    fn:调用的函数;
    timeout:时间差
    */
    function throlle(fn,timeout){
      let time = 0;
      return function(){
        let time1 = new Date().getTime();
        if(time1 - time > timeout){
          fn.call(this)
        } else {
          time = time1
        }
      }
    }
    throlle(func,200);
相关推荐
蓝银草同学2 分钟前
MySQL SQL语法详解:带注释的实用示例
前端·数据库
全栈技术负责人11 分钟前
Cursor技术文档:前端开发的“断舍离”高效协作指南
前端·ai·ai编程
程序员码歌27 分钟前
短思考第270天,2025年赚麻的风口,2026年必冲赛道
前端·ai编程·创业
Hui Baby28 分钟前
saga json文件阅读
java·前端·数据库
一点一木29 分钟前
2025 年终技术复盘:从传统编程到 Vibe Coding 的工作流跃迁
前端·人工智能·程序员
一点一木31 分钟前
程序员一天的视线,都消耗在什么地方?
前端·程序员
G_GreenHand1 小时前
vue自定义日历
前端·javascript·vue.js
冴羽1 小时前
前端性能革命:200 行 JavaScript 代码实现 Streaming JSON
前端·javascript·react.js
inksci1 小时前
上传文件可以用飞帆的组件
前端·javascript
DIKKOO1 小时前
React 19 修复了一个遗留多年的类型乌龙,过程竞如此曲折
前端·react.js