美文网首页
防抖和节流

防抖和节流

作者: 沉默紀哖呮肯伱酔 | 来源:发表于2020-06-08 11:26 被阅读0次

防抖

防抖函数: 短时间内大量触发同一个函数,只会执行一次。实现原理是设置一个定时器,在约定时间后再触发事件处理,每次触发事件都会重置计时器,直到约定时间内没有第二次操作才会执行。
防抖函数常用于搜索框/滚动条的监听事件处理。如果不做防抖,每输入一个字/滚动屏幕,都会触发事件处理,造成性能浪费。

/**
  fn 目标函数
  wait 间隔时间
  immediate 是否立即执行
*/
 const debounce = (fn,awit,immediate) => {
  let timer;
  return (...arg)=>{
      if(timer){
        clearTimeout(timer)
      }
      // timer 为空表示首次触发
      if (immediate && !timer) {
          fn(...arg)
          immediate = false
          return
      }
      timer = setTimeout(()=>{
        fn(...arg)
      },wait)
  }
}

节流

节流函数: 短时间内大量出发同一个函数,约定时间内只会执行一次,到达约定时间以后才会再次执行,即每隔一段时间才会执行一次。实现原理是设置一个定时器,约定时间后执行事件,如果时间到了,那么执行函数并重置定时器。

const throttle = (fn,awit) => {
  let timer;
  return (...arg)=>{
      if(timer){
       return;
      }
      timer = setTimeout(()=>{
        fn(...arg);
        timer = null;
      },wait)
  }
}

相关文章

  • 谈谈js中的节流和防抖函数

    关于节流和防抖,这篇文章说的很好了,深入lodash源码分析防抖和节流深入篇 | Lodash 防抖和节流是怎么实...

  • JavaScript防抖和节流

    1. 认识防抖和节流 1.1. 对防抖和节流的认识 防抖和节流的概念其实最早并不是出现在软件工程中,防抖是出现在电...

  • 前端性能优化-浅谈js防抖和节流

    浅谈js防抖和节流

  • Javascript 基础

    1、函数防抖和函数节流 【《javascript高级程序设计》里,函数节流是这里讲的函数防抖。】函数防抖: 在事件...

  • js 防抖 节流

    节流 防抖1 防抖2

  • 2019-03-27

    js的防抖和节流 据我所知防抖和节流都是为了优化作用,减轻浏览器和服务端的负担,防抖和节流俩个的英文要记住: de...

  • js的防抖和节流

    js的 防抖(debounce)和 节流(throttle ) 防抖和节流一般用于高频触发事件,属于浏览器性能优化...

  • 手写防抖和节流函数实现

    1. 认识防抖和节流函数 防抖和节流的概念其实最早并不是出现在软件工程中,防抖是出现在电子元件中,节流出现在流体流...

  • 实现防抖和节流

    一、认识防抖和节流函数 防抖和节流的概念其实最早并不是出现在软件工程中,防抖是出现在电子元件中,节流出现在流体流动...

  • 2019-04-24关于节流和防抖

    节流: 应用场景: 防抖: 应用场景: 1.节流 2.防抖

网友评论

      本文标题:防抖和节流

      本文链接:https://www.haomeiwen.com/subject/lvtltktx.html