JS:防抖与节流函数的实现与应用

一、防抖

防抖:一连串操作只执行一次。通过设置一个延迟时间,如果这段时间没有再次执行操作则运行目标函数,否则重新计时。

下面是一个防抖函数代码:

TypeScript 复制代码
let a=1;
const add = () => {
  a++;
};
const debounce = (fun: Function, delay: number) => {
  let timer: any = null;
  return function () {
    clearTimeout(timer);
    timer = setTimeout(() => {
      fun();
    }, delay);
  };
};
const debounceAdd = debounce(add, 1000);

二、节流

节流:立即执行目标函数,接着设定时间间隔,计时结束后才可再次执行目标函数。

TypeScript 复制代码
let a = 0;
const add = () => {
  a++;
};
const throttle = (fun: Function, delay: number) => {
  let timer: any = null;
  return function () {
    if (!timer) {
      fun();
      timer = setTimeout(() => {
        fun();
        timer = null;
      }, delay);
    }
  };
};
const throttleAdd = throttle(add, 1000);
相关推荐
一个处女座的程序猿O(∩_∩)O3 分钟前
UniApp 生命周期全解析:从应用到页面,再到组件的完美协奏曲
前端·uni-app
司铭鸿17 分钟前
祖先关系的数学重构:从家谱到算法的思维跃迁
开发语言·数据结构·人工智能·算法·重构·c#·哈希算法
龙颜19 分钟前
从0-1封装一个React组件
前端·react.js
wavemap29 分钟前
先到先得:免费订阅一年ChatGPT Go会员
开发语言·chatgpt·golang
空空kkk33 分钟前
SpringMVC——异常
java·前端·javascript
DcTbnk43 分钟前
脚本猫中的新建脚本:定时脚本、后台脚本、普通脚本,三个区别
前端
冴羽1 小时前
涨见识了,Error.cause 让 JavaScript 错误调试更轻松
前端·javascript·node.js
一千柯橘1 小时前
Electron 第一步
前端·electron
m***D2861 小时前
JavaScript在Node.js中的内存管理
开发语言·javascript·node.js
我叫张小白。1 小时前
JavaScript现代语法梳理:ES6+核心特性详解
开发语言·javascript·typescript·es6