函数防抖和节流

html和css代码:

<div class="box">1</div>

<style type="text/css">

            .box {

                width: 100px;

                height: 100px;

                background: orange;

                color: #fff;

                font-size: 30px;

                text-align: center;

                line-height: 100px;

                margin: 40px auto;

            }

        </style>

js代码:

var box = document.querySelector(".box");

        var num = parseInt(box.innerHTML);

        var boxTime1=null;

        var boxTime2=null;

        var bol=true;

        console.log(Date.now());

        每隔2秒执行一次(节流):

        box.οnclick=function(){

            if(bol){

                bol=false;

                boxTime2 = setTimeout(function(){

                    num++;

                    box.innerHTML = num;

                    bol=true;

                },2000)

            }

        }

第一次触发(防抖):

        box.οnclick=function(){

            clearTimeout(boxTime1);

            if(bol){

                num++;

                box.innerHTML = num;

                bol=false;

            }

            boxTime1 = setTimeout(function(){

                bol=true;

            },2000);

        }

   只触发最后一次:

        box.οnclick=function(){

            clearTimeout(boxTime1);

            boxTime1 = setTimeout(function(){

                console.log(111111111)

                num++;

                box.innerHTML = num;

            },2000);

        }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值