手写防抖原理&&节流原理,亲历面试题

1、防抖:


  // 防抖:函数的防抖就是在函数需要频繁触发时,留有足够的空间,才会执行一次。
 // 当一次事件触发完以后,隔了一段时间,都没有在触发这个事件,就执行
var Inp = document.getElementById("Inp");

   function debounce(handler, delay) {
       var timer = null;
       return function () { //返回一个函数
           var _this = this, arg = arguments;
           clearTimeout(timer);
           timer = setTimeout(() => {
               handler.apply(_this, arg);  //_this = this 将this指向改为Inp
           }, delay)
       }
   }

   function ajax(e) {
       console.log(e, this.value);
   }
   Inp.oninput = debounce(ajax, 1000);


        /*防抖应用场景:
           实时搜索(keyup)
           拖拽(mousemove)*/

2、节流:


 /*节流:就是预定的一个函数只有在大于等于执行周期时才执行,周期内调用不
 执行,如同水滴积攒一定重量才会下落 */
<div id="num">0</div>
<button id="btn">count</button>
<script>
    var oDiv = document.getElementById("num");
    var oBtn = document.getElementById("btn");
        
    function trottle(handler,wait){
        var lastTime = 0;
        return function(){
            var _this = this;
            var nowTime = new Date().getTime();
            if(nowTime - lastTime > wait){
                handler.apply(_this,arguments);
                lastTime = nowTime;
            }
        }
    }

    function ajax(e){
        console.log(e,this);
        oDiv.innerText = parseInt(oDiv.innerText) + 1;
    }
    oBtn.onclick = trottle(ajax,1000);

        /*应用场景:
                窗口调整(resize)
                页面滚动(scroll)
                抢购疯狂点击(mousedown)*/
</script>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值