函数的防抖和节流

这里只是示例,如果在实际项目中使用的话,这样写是满足不了需求的

<!-- 函数防抖 如果事件触发太快(时间间隔小于我们规定的时间),则只执行最后一次事件的业务代码-->
<!-- 常见例子:搜索框在输入停止后(暂停时间大于我们规定时间)才发起请求-->
  function fn1() {
    let dom = document.body;
    let time;
    dom.addEventListener('mousemove', () => {
      clearTimeout(time);
      time = setTimeout(() => {
        console.log('send ajax fn1');//你的业务代码
      }, 500)
    })
  }
  <!-- 函数节流 无论事件触发多快,只在规定间隔内执行业务代码-->
  <!-- 常见例子:连续点击多次按钮,除了第一次,往后每隔一定时间再次触发事件才执行一次业务代码-->
  function fn2(){
    let dom = document.body;
    let flag = true;
    dom.addEventListener('click', () => {
      if(flag){
        console.log('send ajax fn2');//你的业务代码
        flag = false
        setTimeout(() => {
          flag = true;
        }, 2000)
      }
    })
  }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值