节流防抖最简单的实现

目录

引言

1. 节流:相当于技能cd,等cd过后再点技能才能生效

解释 

效果

2. 防抖 :相当回城,连续点击的最后一次才生效

解释

效果

此外


引言

手写节流防抖函数的可以看我上一篇文章--手写节流与防抖,本文用一个变量在vue中实现节流防抖的功能:

1. 节流:相当于技能cd,等cd过后再点技能才能生效

template:

<button @click="onBtnClick">节流测试</button>

script:

export default {
  name: "App",
  data() {
    return {
      flag:false // 控制点击的标志
    };
  },

  methods: {
    onBtnClick() {
      if(this.flag) return
      this.flag = true
      setTimeout(() => {
        this.flag=false
      }, 1500);
      console.log('执行的逻辑...');
    },
  },
};

解释 

        flag为false的时候才能执行log打印;而除第一次外,只有点击后的1.5后才能变false,不到1.5s时flag被设置为true,则会直接return。

效果

        1.5s内无论点击按钮多少次只会执行一次,从第一次点击时开始计时1.5s。如图

2. 防抖 :相当回城,连续点击的最后一次才生效

script:

export default {
  name: "App",
  data() {
    return {
      time: null // 时间标志
    };
  },

  methods: {
    onBtnClick() {
      if (this.time) {
        clearTimeout(this.time);
      }
      this.time = setTimeout(() => {
        console.log('需要执行的相关逻辑');
        this.time = null;
      }, 1500);
       
    },
  },
};

解释

        首次点击(触发)时time为null跳过if语句并开始计时,1.5s内若再点击(触发)则会走if语句清空时间,加上后续的定时器保证了每次以最后点击1.5s后才执行log打印

效果

        1.5s内多次点击按钮以最后一次点击时开始计时1.5s后执行相关逻辑。演示 

此外

        a. setTimeout 是有返回值的(不是时间戳!), 表示当前setTimeout在页面中的所有setTimeout中的序号;这个值可以传递给 clearTimeout 来取消该定时器。

       b. 上述代码中即使去掉 " this.time = null  " 这句,会发现不会影响上述效果,只是因为该demo太简洁。这句代码会影响if语句的执行,倘若if语句中还有其他逻辑可能会导致多次点时出现频繁执行。

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小白目

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值