前端中预防多次重复事件

想到防止重复事件,想到的的一个是防抖节流函数,其可以有效防止重复事件。但用css也可以很简单的解决这个问题

一个按钮为了避免重复提交或考虑服务器容载问题,往往需要考虑对点击行为进行限制,就比如500ms提交,这个时候大家往往去网页搜索防抖节流cv一下,接下来的方法可以简单记住,还能更加直观的观看限制过程。

我们要对点击事件进行限制,而css中有个pointer-events可以对需要的点击事件进行限制,然后就是防止重复,对时间的把握,就是禁用一段时间后恢复,这个时候就想到了动画,用animation,或者transition。而还需要有个伪元素去出发点击事件,那就是:active

这种场景就是,对css的动画控制,从禁用到可点击的过程变化,每次点击时动画执行一次,而执行过程中就是处于禁用状态,这就达到了节流的效果

所以我们将他们串联起来就有,点击时出发原有事件后,对其禁用2s,后恢复正常。

用animation,设置有个动画名称就叫throttle

用一个按钮绑定一个点击事件,根据动画设置,将其按钮设置成禁用到可点击的过程。animation设置动画的缓动函数阶梯曲线step-end,即pointer-events变化时间点,而forwards就是会一直保持all,动画结束这个状态。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值