美文网首页
js防抖与节流

js防抖与节流

作者: 壹直卝注你 | 来源:发表于2019-08-01 17:27 被阅读0次

1.节流(throttle)

定义:先定义个执行周期,当时间执行时间大于等于执行周期,那就进入新的周期;如果小于执行周期就等事件执行结束后执行回调

案例:throttle 就好比将水龙头拧紧直到水是以水滴的形式流出,那你会发现每隔一段时间,就会有一滴水流出;

function throttle(fn, gapTime) { //节流
     let _lastTime = null;

     return function () {
     let _nowTime = + new Date()
     if (_nowTime - _lastTime > gapTime || !_lastTime) {
        fn();
       _lastTime = _nowTime
     }
    }
};
//resize测试
function task() {
      console.log(window.document.body.clientWidth)
}
window.addEventListener('resize',debounce(task,200),false)

2.防抖(debounce)

定义:防抖就是一个事件完成后n毫秒之后再执行回调,如果这n毫秒内又重复一次事件,就重新计算时间;

举例:debounce你在进入电梯后发现这时不远处走来了了一个人,等 10 秒钟,这个人进电梯后不远处又有个妹纸姗姗来迟,怎么办,再等 10 秒,于是妹纸上电梯时又来了一对好基友...,作为感动中国好码农,你要每进一个人就等 10 秒,直到没有人进来,10 秒超时,电梯开动。

        function debounce(fn, wait) { //防抖
            var timer = null;
            return function () {
                var context = this
                var args = arguments
                if (timer) {
                    clearTimeout(timer);
                    timer = null;
                }
                timer = setTimeout(function () {
                    fn.apply(context, args)
                }, wait)
            }
        };
      //resize测试
        function task() {
            console.log(window.document.body.clientWidth)
        }
        window.addEventListener('resize',debounce(task,200),false)

总结

throttle 可以想象成阀门一样定时打开来调节流量,它适合指定每隔一定时间间隔内执行不超过一次的情况
例如 拖动滚动条(scroll),resize,移动鼠标的事件处理等

debounce 可以想象成把很多事件压缩组合成了一个事件,它适合只执行一次的情况
例如 搜索框中的自动完成。在停止输入后提交一次 ajax 请求;keyup事件等

相关文章

  • 函数节流与函数防抖

    函数节流与函数防抖的区别JS魔法堂:函数节流(throttle)与函数去抖(debounce)函数的防抖与节流 自...

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

    浅谈js防抖和节流

  • 防抖和节流

    一、防抖:只执行最后一次 js防抖方法 一、节流:控制执行次数 节流

  • JavaScript:函数防抖与节流

    什么是函数防抖与节流? 函数节流和函数防抖,两者都是优化高频率执行js代码的一种手段。 定义: 防抖: n 秒后在...

  • 微信小程序防抖、节流的使用

    1、防抖、节流函数的封装 在utils文件夹下新建utils.js文件,然后写入节流和防抖函数 在.js页面引入并使用:

  • js函数的防抖(debounce)与节流(throttle)

    js 函数的防抖(debounce)与节流(throttle)[https://www.cnblogs.com/c...

  • js的防抖和节流

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

  • JS 节流与防抖

    本文的主角是节流 throttle 与防抖 debounce。 区别节流强调的是m秒内函数最多触发一次,注意这里的...

  • js防抖与节流

    在前端开发中会遇到一些频繁的事件触发,例如input,keyup,keydown,scroll,resize,mo...

  • js防抖与节流

    1.节流(throttle) 定义:先定义个执行周期,当时间执行时间大于等于执行周期,那就进入新的周期;如果小于执...

网友评论

      本文标题:js防抖与节流

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