JS节流防抖

节流防抖是为了解决JS事件高频率触发问题而设计的一种方法
节流:一个事件周期内,如果一个事件频繁触发,只运行一次(以次数为限制)
防抖:一个事件周期内,如果一个事件频繁触发,只运行上一个时间周期的一次触发(以时间周期为限制)
*****
节流-例:
<body>
    <h2>节流</h2>
    <span id="count">0</span>
    <button id="btn"type="button">click</button>
</body>
<script>
    var btn document.getElementById("btn");
    var count document.getElementById("count");
    //string Number Boolean(包装类)
    btn.onclick =thowttle(sum,2000)    //    sum-要执行的方法;2000-执行周期
//----正常触发----
    function sum(){
        //count.innerHTML=Number(count.innerHTML)+1
        count.innerHTML= +count.innerHTML+1
    }
//----节流:2000ms内只触发一次----
    function thowttle(callback,delay){
       
var lastTime =0;
return function(){
    var currentTime=new Date().getTime()
    if(currentTime-lastTime >delay){
        callback();
        lastTime=currentTime
    }
}
</script>
*****
防抖
//onchange-表单元素发生变化并失焦时触发
//oninput-表单元素发生变化时触发
<body>
    <h2>防抖</h2>
    <input id="keyword" type="texture">
</body>
<script>
    var keyword=document.getElementById("keyword");
    var timeid=false
    keyword.οninput=function(){
        if(timeid){
            clearTimeout(timeid)
        }
        timeid=setTimeout(()=>{
            console.log(this.value)
        },2000)
    }
</script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值