【js高频八股】防抖与节流

1)函数防抖:单位时间内,频繁触发事件,只执行最后一次(重新开始)

是指在事件被触发 n 秒后再执行回调,如果在这 n 秒内事件又被触发,则重新计时。这可以使用在一些点击请求的事件上,避免因为用户的多次点击向后端发送多次请求。

**应用场景:**搜索框搜索输入(一定时间后再发送请求)、文本编辑器的保存(一定时间后再自动保存)

实现:利用定时器 如果事件在n秒内又被触发 那么清空计时器重新开始计时

复制代码
// 函数防抖的实现
function debounce(fn, wait) {
  var timer = null;
  return function() {
    var context = this,
      args = arguments;
    // 如果此时存在定时器的话,则取消之前的定时器重新记时
    if (timer) {
      clearTimeout(timer);
      timer = null;
    }
    // 设置定时器,使事件间隔指定事件后执行
    timer = setTimeout(() => {
      fn.apply(context, args);
    }, wait);
  };
}

2)函数节流:单位时间内,频繁触发事件,只执行一次(一旦执行,不要打断)

是指规定一个单位时间,在这个单位时间内,只能有一次 触发事件的回调函数执行,如果在同一个单位时间内某事件被触发多次,只有一次能生效 。节流可以使用在 scroll 函数 的事件监听上,通过事件节流来降低事件调用的频率。

应用场景:高频事件(快速点击、resize、scroll)下拉加载、视频播放记录时间等

实现:利用计时器,如果在n秒内 事件又被触发 那么直接退出 不会影响之前程序的执行

复制代码
// 函数节流的实现;
function throttle(fn, delay) {
  var preTime = Date.now();
  return function() {
    var context = this,
      args = arguments,
      nowTime = Date.now();
    // 如果两次时间间隔超过了指定时间,则执行函数。
    if (nowTime - preTime >= delay) {
      preTime = Date.now();
      return fn.apply(context, args);
    }
  };
}
相关推荐
云泽8081 小时前
C++11 核心特性全解:列表初始化、右值引用与移动语义实战
开发语言·c++
froginwe112 小时前
DOM 加载函数
开发语言
Hello eveybody2 小时前
介绍一下背包DP(Python)
开发语言·python·动态规划·dp·背包dp
北山有鸟2 小时前
修改源码法和插件法
嵌入式硬件·学习
richxu202510012 小时前
嵌入式学习之路->stm32篇->(14)通用定时器(上)
stm32·单片机·嵌入式硬件·学习
AI进化营-智能译站2 小时前
ROS2 C++开发系列12-用多态与虚函数构建可扩展的ROS2机器人行为模块
开发语言·c++·ai·机器人
iCxhust2 小时前
微机原理实践教程(C语言篇)---A002流水灯
c语言·开发语言·单片机·嵌入式硬件·51单片机·课程设计·微机原理
小陈phd2 小时前
TensorRT 入门完全指南(一)——从核心定义到生态工具全解析
人工智能·笔记
是上好佳佳佳呀2 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记