防抖与节流

防抖与节流

1.防抖
高频率事件在 n 秒内只触发一次,如果再次被触发,则重新计时
方案
设置定时器,当 n 秒内再次被触发,则清除定时器。

<button id="btn">提交</button>
<script >
document.getElementById('btn').addEventListener('click', submit)
function submit(){
    console.log('请求数据')
}
</script>

上面是最简单的提交按钮,现在的需求是点击按钮,请求后台的数据。
如果按照上面的代码,可以实现,但是如果用户连续点击,就在造成资源浪费。这里就用到了防抖。

document.getElementById('btn').addEventListener('click', debounce)
let timer = null
function debounce(){
    clearTimeout(timer)
    timer = setTimeout(function() {
        submit()
    }, 1000)
}

function submit(){
    console.log('请求数据')
}

2节流
高频率事件在 n 秒内只触发一次,n 秒内不再触发。
方案
还是基于上面的例子

document.getElementById('btn').addEventListener('click', throttle)

let flag = true
function throttle(){
    if (!flag) return
    flag = false
    setTimeout(function(){
        submit()
        flag = true
    },1000)
}
function submit(){
    console.log('请求数据')
}

上面定义了一个标记 flag 表示当前函数执行状态,如果以及过了 1 秒,请求数据执行后,我们将 flag 设置成 true,
说明函数可重新执行,否则就直接返回,不执行 setTimeout。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值