懒加载事件-函数节流

作者: 苏茶茉芳_亚泽伊 | 来源:发表于2019-07-04 17:26 被阅读1次

我们在web项目中经常会需要用到 图片懒加载 ,设置中我们需要监听scroll滚动条滚动事件 。这种事件响应得十分频繁,当我们监听器的回调函数越复杂,对性能影响就会越严重。为此我们利用定时器,使事件回调函数在监听中按照固定的事件间隔触发,而不是每像素移动都触发。

跟普通的事件监听设置基本一样,我们只要对回调函数体进行一次封装。
这里我封装了一个函数,参考了小程序API的设计模式,我们只传递一个map。

lazyEvent.throttle({
        dom: window, // 绑定事件监听的dom
        eventName: 'scroll', // 监听什么事件
        delay: 100, // 回调函数触发的时间间隔
        event: res => { // 回调函数执行了什么
          console.log(1)
        }
      })

接下来我们只需要看懂下文标记的10行左右代码即可学会函数节流

export class lazyEvent {
  constructor() {}
  /* 函数节流 */
  static throttle(map){
    /* 取map传进来的值 */
    let DOM = map.dom
    let eventName = map.eventName
    let event = map.event
    let delay = map.delay ? map.delay : 100
    
    /* ----------------这里是重点↓ ------------------*/
    let timer = null  // 外部定义timer变量,用来存定时器ID
    let newEvent = function () {  //  声明一个新函数,用来包裹我们目标函数体
      if(timer){  //  如果有定时器就不继续执行下面的代码
        return
      }else{  //  如果没有定时器就执行目标函数体,然后设置一个定时器
        event()  //  目标函数体

        timer = setTimeout(function () {  // 这个定时器一个时间间隔后会销毁自身
          clearTimeout(timer)
          timer = null
        },delay)

      }
    }
    /* -----------------这里是重点↑ --------------------*/


    DOM.addEventListener(eventName, newEvent)
  }
}

1.首先呢,这个 newEvent就是一层皮,里面包了我们 真正要执行的事件响应,以及我们本次要添加的一个定时器
2.定时器函数的返回值是这个 定时器的ID 我们需要在 '皮' 外 存一下。
3.这个定时器的回调函数就是销毁它自身,并且清空我们存储的ID,所以我们可以通过ID判断当前有没有定时器。
4.我们进入 '皮' 里有一个判断,现在有定时器吗? 如果有我们就立即结束本次响应。如果没有我们就执行我们的目标 -- 响应事件,然后没有我们就再做一个定时器呗。

以上就是函数节流的主要内容,希望大家能够学会。ps.类似的事件还有resize,mousemove这种。

相关文章

  • 懒加载事件-函数节流

    我们在web项目中经常会需要用到 图片懒加载 ,设置中我们需要监听scroll滚动条滚动事件 。这种事件响应得十分...

  • 懒加载+函数节流

  • 利用函数节流完成图片懒加载

    图片懒加载比较适合用函数节流如果利用函数防抖,那么加载过程中页面一直空白也不合适

  • 瀑布流+懒加载+函数节流

  • 懒加载与节流

    1. 概念 懒加载也叫延迟加载,指的是在长网页中延迟加载图像,是一种很好优化网页性能的方式。 用户滚动到它们之前...

  • 函数节流(throttle)与懒加载(lazyload)

    与函数去抖类似,函数节流是也是为了防止过多的DOM操作导致浏览器崩溃问题。但其思想与函数去抖不同,可以拿咖啡机打比...

  • 函数节流和函数防抖

    函数节流 还记得上篇文章中说到的图片懒加载吗?我们在文章的最后实现了一个页面滚动时按需加载图片的方式,即在触发滚动...

  • Javascript 基础

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

  • 防抖与节流

    防抖:事件持续触发,但只有当事件停止触发后n秒才执行函数。 节流:事件持续触发时,每n秒执行一次函数。 防抖 节流

  • swift学习09(懒加载)

    swift中是通过专门的关键字(lazy)来实现懒加载; 一、直接懒加载赋值 二、懒加载赋一个函数 三、懒加载赋一...

网友评论

    本文标题:懒加载事件-函数节流

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