美文网首页
Javascript 事件节流和防抖

Javascript 事件节流和防抖

作者: 我是一个前端 | 来源:发表于2019-01-11 14:28 被阅读0次

事件节流和防抖是为了解决开发过程中遇到性能问题,常见于onscroll、onresize,频繁点击button等

事件节流

设置一个时间间隔,时间间隔内只允许执行一次,好像客运站大巴,到点才会走。

问题:

多年前遇到过一个onresize问题,页面满屏布局,模块很多dom结构也相对复杂。所以在窗口频繁快速变化大小的时候页面反应异常卡顿。

解决办法:

说实话当初意识到是性能问题不过不知道怎么解决,搜索了很多相关问题,最后在https://stackoverflow.com找到了解决办法,遗憾的是具体的链接忘了。不过也是因为这个问题宋词爱上了这个网站,问题答案很靠谱。

//问题解决的原理就是事件节流

window.onresize = () => {
      console.log('resize')
}

随便晃几下执行了150多次,这也就是卡顿的根源。


image.png

解决这个问题我们需要减少执行次数。

          let timer = null
          window.onresize = () => {
                console.log(timer)
                if (!timer) {
                    timer = setTimeout(() => {
                        callBack()
                        timer = null
                    }, 1000)
                }
            }

            function callBack() {
                console.log('resize')
            }
image.png

这样不管我们一秒内晃动多少次callBack只执行一次,问题解决接下在封装一下

//封装前我们先思考一下,首先既然是封装那么事件不一定都是onersize、间隔时间得有用户设置、callBack得是用户写。

**其实我们只关心callBack,和执行间隔时间,恰好事件都有回调

            function callBack() {
                console.log('resize')
            }

            function throttle(callBack, time) {
                let timer = null
                //timer状态要常驻内存,这里做了一个闭包
                return function() {
                    if (!timer) {
                        timer = setTimeout(() => {
                            callBack()
                            timer = null
                        }, time)
                    }
                }
            }

            window.addEventListener('resize', throttle(callBack, 1000), false)

测试完美!

防抖

常用于验证码防刷,按钮频繁点击导致发起多次请求给服务端造成压力,代码策略是,一段时间内事件统一处理,防抖原理类似 趴活的黑车,永远喊得就差一位上车就走,等你上去他接着喊就差一位上车就走。。。 擦有点乱 看代码吧

//需求就是input输入内容停顿间隔1000ms后触发callback

            let oInput = document.querySelector('input')
                // oInput.addEventListener('input', function(e) {
                //     //如果直接每次onInput发请求,会导致性能问题
                //     console.log(e, this)
                // })

            oInput.addEventListener('input', debounce(callback, 500))

            function debounce(fn, delay) {
                let timer = null
                    // 绑定上下文this
                let self = this
                return function() {
                    let arg = arguments
                        // 每次清楚定时器
                    clearTimeout(timer)
                        // 重新打开定时器,做到只有最后一次执行了
                    timer = setTimeout(() => {
                        // 绑定this,传入参数给callback。通常我们需要事件对象就ok
                        fn.apply(this, arg)
                    }, delay)
                }
            }

            function callback(e) {
                console.log('触发', e.target.value)
            }

            function callback(e) {
                console.log('触发', e.target.value)
            }
image.png

输入了很多内容 最后触发了一次callback,效果完美!

您的吐槽or点赞是我的动力!

相关文章

  • Javascript 基础

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

  • Javascript 事件节流和防抖

    事件节流和防抖是为了解决开发过程中遇到性能问题,常见于onscroll、onresize,频繁点击button等 ...

  • js的防抖和节流

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

  • 彻底弄懂函数防抖和函数节流

    函数防抖和节流 函数防抖和函数节流:是优化高频率执行的JavaScript代码的一种手段。常用于JavaScrip...

  • js 防抖 节流 JavaScript

    js 防抖 节流 JavaScript 实际工作中,通过监听某些事件,如scroll事件检测滚动位置,根据滚动位置...

  • 函数防抖和函数节流

    函数防抖和函数节流 函数防抖和函数节流:是优化高频率执行的JavaScript代码的一种手段。常用于JavaScr...

  • 每日一题:防抖,节流

    防抖(debounce)和节流(throttle)的核心思想都是为了减少调用事件的频率,以提高性能。 防抖和节流的...

  • 在 Vue 中使用lodash对事件进行防抖和节流

    事件节流和防抖是提高性能或降低网络开销的好方法。虽然 Vue 1曾经支持对事件的节流和防抖,但是在Vue 2中为了...

  • JavaScript防抖和节流

    无论是防抖还是节流都是为了避免回调函数中的处理随着连续触发事件每次都执行 防抖和节流都是为了防止函数(事件)的连续...

  • 防抖和节流 javascript

    防抖(Debounce)指触发事件后在 n 秒内函数只能执行一次,如果在 n 秒内又触发了事件,则会重新计算函数执...

网友评论

      本文标题:Javascript 事件节流和防抖

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