2021-09-28

防抖与节流函数的封装使用

一、防抖函数封装

// 防抖函数
function debounce(fn,delay) {
    let timer;
    return function () {
        clearTimeout(timer);
        timer = setTimeout(() => {
            fn.apply(this,arguments);
        },delay);
    }
}


window.onscroll = debounce(function () {
    let scrollTop = document.body.scrollTop || document.documentElement.scrollTop;
    console.log('滚动条位置:' + scrollTop);
},200) 

二、节流函数的封装

<input type="text" value="" id="input">

<script>
   // 节流函数
   function throttle(fn, delay) {
       let flag = true;
       return function () {
           if (!flag) { return; }
           flag = false;
           setTimeout(() => {
               fn.apply(this, arguments);
               flag = true;
           }, delay);
       }
   }


   $('#input').on('keyup', throttle(function () {
       console.log($(this).val());
       // ajax后台请求....
   }, 1000));
</script> 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值