防抖与节流

前段时间看了看防抖和节流,觉得用处很大,于是自己动手整了下写了写思路,话不多少开始造。
我们先来看一个简单的例子,下面的代码简单的写了一个为窗口添加滚动条事件,并打印滚动条的位置。

    var k=0;
    function showTop() {
        //谷歌不识别document.documentElement.scrollTop,必须要加上document.body.scrollTop
        var ing = document.body.scrollTop || document.documentElement.scrollTop;
        console.log('滚动条位置:'+ing+'    调用了多少次:'+k+++'次');
    }
    //为窗口添加滚动事件
    window.onscroll = showTop;

按照我简陋的想法来说,从开始滑动到滑动停止难道不就是一次事件么?


然而现实给了我一个残酷的打击


短短的一个距离居然调用了20次方法,这还得了!要是我手贱加点东西进去,我这个程序不就要炸掉!阔怕.jpg
俗话说的好:只要思想不滑坡,办法总比困难多。于是我用我颤抖的右手点进了百度,解决方法如下

防抖(debounce)

思路:在第一次触发事件时,不立即触发函数,等过了规定的时间(比如0.5秒)再触发。
如果在0.5秒内没有再次触发事件,那么就执行函数,反之就不执行,计时重新开始。

效果:如果同一时间内大量触发事件,只会执行一次函数。

代码实现

function debounue(fn,time){
        let Tdata = '';//闭包
        return function(){
            if(Tdata){
                clearTimeout(Tdata);
            }
            Tdata = setTimeout(fn,time);
        }
    }
    var k = 0;
    function showTop() {
        //谷歌不识别document.documentElement.scrollTop,必须要加上document.body.scrollTop
        var ing = document.body.scrollTop || document.documentElement.scrollTop;
        console.log('滚动条位置:'+ing+'    调用了多少次:'+k+++'次');
    }
    //为窗口添加滚动事件
    window.onscroll = debounue(showTop,500);

运行以上代码,你将会看到无论你滚动条滚动多少下,它只会在你停下0.5秒后运行一次。
哈哈哈,完成了,小菜用颤抖的双手缓缓的把代码写上去,这时需求走了过来,看了看我的功能,展开了一场对话

需求:你这个不行啊,和我要的不一样(沉思脸)
小菜:(震惊)这不是你说的效果么
需求:(笑着拍了拍我的肩膀)年轻人,不要总想着一条思路嘛,再多想想,我看好你哦。
小菜:(缓缓的点了点头,并把40长的大刀拿了出来)

没办法,需求说啥就是啥

节流(throttling)

思考:如果用户不停的触发滚动事件,也可以在间隔某个时间后给出反馈:比如用户不停的滑动十秒,我以每两秒一次的间隔时间,运行了五次

代码实现:

function throttle(fn,time){
        let Tdata = true;
        return function(){
            if(!Tdata){
                return;
            }
            //在间隔期内把状态设置无效
            Tdata = false;
            setTimeout(()=>{
                fn();
                Tdata = true;
            },time);
        }
    }
    var k = 0;
    function showTop() {
        //谷歌不识别document.documentElement.scrollTop,必须要加上document.body.scrollTop
        var ing = document.body.scrollTop || document.documentElement.scrollTop;
        console.log('滚动条位置:'+ing+'    调用了多少次:'+k+++'次');
    }
    //为窗口添加滚动事件
    window.onscroll = throttle(showTop,1000);

复制以上代码得到的结果:不停的拖动滚动条,它会一开始运行一次,并每隔1秒再次运行,停止滚动后还会运行一次

好了,以上就是防抖和节流的使用方法,方法有很多种,看大家怎么去实现了,菜鸟笔记,大佬喷的时候麻烦指出错误,我会一一修改
<附上大佬链接:https://css-tricks.com/debouncing-throttling-explained-examples/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342