成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

2019.04.04 防抖和節(jié)流

SegmentFault / 604人閱讀

摘要:只記錄簡單實現(xiàn)方法用以明白原理防抖,去抖動。周期結(jié)束后,又有事件觸發(fā),開始新的周期。節(jié)流策略也分前緣和延遲兩種。簡單版定時器期間,只執(zhí)行最后一次操作

只記錄簡單實現(xiàn)方法、用以明白原理

防抖

debounce,去抖動。策略是當(dāng)事件被觸發(fā)時,設(shè)定一個周期延遲執(zhí)行動作,若期間又被觸發(fā),則重新設(shè)定周期,直到周期結(jié)束,執(zhí)行動作。 這是debounce的基本思想,在后期又擴展了前緣debounce,即執(zhí)行動作在前,然后設(shè)定周期,周期內(nèi)有事件被觸發(fā),不執(zhí)行動作,且周期重新設(shè)定
// 暴力版: 定時器期間,有新操作時,清空舊定時器,重設(shè)新定時器
var debounce = (fn, wait) => {
    let timer, timeStamp=0;
    let context, args;
 
    let run = ()=>{
        timer= setTimeout(()=>{
            fn.apply(context,args);
        },wait);
    }
    let clean = () => {
        clearTimeout(timer);
    }
 
    return function(){
        context=this;
        args=arguments;
        let now = (new Date()).getTime();
 
        if(now-timeStamp < wait){
            console.log("reset",now);
            clean();  // clear running timer 
            run();    // reset new timer from current time
        }else{
            console.log("set",now);
            run();    // last timer alreay executed, set a new timer
        }
        timeStamp=now;
 
    }
 
}
節(jié)流

throttling,節(jié)流的策略是,固定周期內(nèi),只執(zhí)行一次動作,若有新事件觸發(fā),不執(zhí)行。周期結(jié)束后,又有事件觸發(fā),開始新的周期。 節(jié)流策略也分前緣和延遲兩種。與debounce類似,延遲是指 周期結(jié)束后執(zhí)行動作,前緣是指執(zhí)行動作后再開始周期。
// 簡單版: 定時器期間,只執(zhí)行最后一次操作
var throttling = (fn, wait) => {
    let timer;
    let context, args;
 
    let run = () => {
        timer=setTimeout(()=>{
            fn.apply(context,args);
            clearTimeout(timer);
            timer=null;
        },wait);
    }
 
    return function () {
        context=this;
        args=arguments;
        if(!timer){
            console.log("throttle, set");
            run();
        }else{
            console.log("throttle, ignore");
        }
    }
 
}

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/104424.html

相關(guān)文章

  • 詳談js抖和節(jié)流

    摘要:本文會分別介紹什么是防抖和節(jié)流,它們的應(yīng)用場景,和實現(xiàn)方式。防抖和節(jié)流都是為了解決短時間內(nèi)大量觸發(fā)某函數(shù)而導(dǎo)致的性能問題,比如觸發(fā)頻率過高導(dǎo)致的響應(yīng)速度跟不上觸發(fā)頻率,出現(xiàn)延遲,假死或卡頓的現(xiàn)象。 本文由小芭樂發(fā)表 0. 引入 首先舉一個例子: 模擬在輸入框輸入后做ajax查詢請求,沒有加入防抖和節(jié)流的效果,這里附上完整可執(zhí)行代碼: 沒有防抖 ...

    shevy 評論0 收藏0
  • 徹底弄懂函數(shù)抖和函數(shù)節(jié)流

    摘要:若時間差大于間隔時間,則立刻執(zhí)行一次函數(shù)。不同點函數(shù)防抖,在一段連續(xù)操作結(jié)束后,處理回調(diào),利用和實現(xiàn)。函數(shù)防抖關(guān)注一定時間連續(xù)觸發(fā)的事件只在最后執(zhí)行一次,而函數(shù)節(jié)流側(cè)重于一段時間內(nèi)只執(zhí)行一次。 原博客地址,歡迎star 函數(shù)防抖和節(jié)流 函數(shù)防抖和函數(shù)節(jié)流:優(yōu)化高頻率執(zhí)行js代碼的一種手段,js中的一些事件如瀏覽器的resize、scroll,鼠標的mousemove、mouseover...

    Mr_houzi 評論0 收藏0
  • 函數(shù)抖和節(jié)流

    摘要:應(yīng)用場景給按鈕加函數(shù)防抖防止表單多次提交。對于輸入框連續(xù)輸入進行驗證時,用函數(shù)防抖能有效減少請求次數(shù)。參考十分鐘學(xué)會防抖和節(jié)流輕松理解函數(shù)節(jié)流和函數(shù)防抖 函數(shù)防抖和節(jié)流 防抖 對于觸發(fā)非常頻繁又沒有必要每次都執(zhí)行的事件,希望合并到一次去執(zhí)行; 實現(xiàn)思路: 事件觸發(fā)后,在規(guī)定的時間范圍內(nèi)如果事件重復(fù)觸發(fā),那么忽略之前觸發(fā)的事件,并且重新開始計時,直到某一次事件觸發(fā)后大于規(guī)定時間,我們才執(zhí)...

    daydream 評論0 收藏0
  • JavaScript抖和節(jié)流

    摘要:概念函數(shù)防抖和函數(shù)節(jié)流,兩者都是優(yōu)化高頻率執(zhí)行代碼的一種手段。防抖任務(wù)頻繁觸發(fā)的情況下,只有任務(wù)觸發(fā)的間隔超過指定間隔的時候,任務(wù)才會執(zhí)行。節(jié)流指定時間間隔內(nèi)只會執(zhí)行一次任務(wù)一定時間內(nèi)方法只跑一次。 概念 函數(shù)防抖和函數(shù)節(jié)流,兩者都是優(yōu)化高頻率執(zhí)行js代碼的一種手段。 防抖:任務(wù)頻繁觸發(fā)的情況下,只有任務(wù)觸發(fā)的間隔超過指定間隔的時候,任務(wù)才會執(zhí)行。 節(jié)流:指定時間間隔內(nèi)只會執(zhí)行一次任...

    DevWiki 評論0 收藏0
  • 函數(shù)的抖和節(jié)流是個啥???

    摘要:函數(shù)防抖和節(jié)流,都是控制事件觸發(fā)頻率的方法。封裝一個函數(shù),讓持續(xù)觸發(fā)的事件監(jiān)聽是我們封裝的這個函數(shù),將目標函數(shù)作為回調(diào)傳進去,等待一段時間過后執(zhí)行目標函數(shù)第二點實現(xiàn)了,再看第一點持續(xù)觸發(fā)不執(zhí)行。 曾經(jīng)面試時候被問到過這個,年少的我一臉無知。。。 后來工作中遇到了一個場景:輸入名稱的同時去服務(wù)器校驗名稱是否重復(fù),但發(fā)現(xiàn)之前的代碼竟然都沒做限制,輸入一次發(fā)一次請求。簡直忍不了,就在項目的u...

    edagarli 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<