【前端】防抖和节流

防抖

防抖用于限制连续触发的事件的执行频率。当一个事件被触发时,防抖会延迟一定的时间执行对应的处理函数。如果在延迟时间内再次触发了同样的事件,那么之前的延迟执行将被取消,重新开始计时。

总结:在单位时间内频繁触发事件,只有最后一次生效

场景 :用户在输入框输入1个字符都会发送请求,正常是全部输入完成才发送

项目中遇到的场景,需要鼠标悬浮在图表的时候,将ToolsTip里的数据回显到头部,由于是2张图表,无法直接赋值,必须通过请求后端接口,由于ToolsTip里的Api是鼠标放上面就会触发,就会出现发起了N个请求,这时候就可以利用防抖,只有一定时间没有动作,才会请求后端接口。

vue中

js 复制代码
	//防抖方法,传入函数和延迟
    debounce(fn, delay) {
      let timer = null;              //默认是空
      return function () {
        if (timer) {                 //如果存在则
          clearTimeout(timer);       //清空定时器
        }
        timer = setTimeout(() => {   //赋值定时器
          fn();
        }, delay);
      };
    },

监听echarts的tooltip 事件

js 复制代码
      let charts = document.getElementById('line_charts');
      let myChart = this.$echarts.init(charts);
      myChart.on(
        'showTip',
        this.debounce(() => {
          that.getData();
        }, 2000)
      );

如果是监听input输入框

参考如下:

js 复制代码
    const inputDOM = document.getElementById('input')
    function debounce(fn, delay) {
      let timer = null
      return function () {
        if (timer) {
          clearTimeout(timer)
        }
        timer = setTimeout(() => {
          fn()
        }, delay)
      }
    }
    inputDOM.addEventListener(
      'input',
      debounce(() => {
        console.log('发送请求')
      }, 500)
    )

节流

节流是一种限制函数执行频率的技术。它可以确保在某个时间段内,函数不会被连续触发执行,而是以一定的时间间隔执行。

总结:一段时间内只执行一次

函数节流的常见应用场景是在处理频繁触发的事件,例如验证码刷新、窗口滚动、鼠标点击等。通过使用函数节流,可以减少事件处理函数的执行次数,提高性能和响应速度。

传入需要节流的函数和延迟即可

js 复制代码
    //节流 一段时间内只执行一次
    // 第一次执行cd为true,执行定时器,快速第二次进由于定时器还没有结束,cd为true,所以不执行,等待定时器结束,cd为false,执行新一轮
    function throttle(fn, delay) {
      let cd = false
      return function () {
        if (cd) {
          console.log('节流中')
          return false
        }
        cd = true
        setTimeout(() => {
          fn()
          cd = false
        }, delay)
      }
    }
相关推荐
独自破碎E几秒前
【双指针】接雨水
java·开发语言
小北方城市网3 分钟前
MyBatis-Plus 生产级深度优化:从性能到安全的全维度方案
开发语言·redis·分布式·python·缓存·性能优化·mybatis
小雨青年4 分钟前
Cursor 项目实战:AI播客策划助手(四)—— 产品发布与交付收尾
前端·人工智能
@呵呵8 分钟前
上传图片裁剪
开发语言·javascript·vue.js
zfj32119 分钟前
好书分享:《两周自制脚本语言》-用java实现一个脚本语言
java·开发语言·python·编译原理
晚霞的不甘20 分钟前
Flutter for OpenHarmony《淘淘购物》主页点击跳转功能详解:从 UI 响应到页面导航的完整实现
前端·flutter·ui·搜索引擎·前端框架·交互
u01092727120 分钟前
自定义类型转换机制
开发语言·c++·算法
cooldream200921 分钟前
前端技术架构详解:Vue 3 + TypeScript + Vite 在具身 AI 系统中的实践
前端·架构·typescript
爱吃生蚝的于勒22 分钟前
【Linux】进程信号的产生(一)
linux·运维·服务器·c语言·开发语言·数据结构·c++
写代码的【黑咖啡】27 分钟前
Python中Excel文件的强大处理工具:OpenPyXL
开发语言·python·excel