前端 - 还在用 JS 做节流吗?CSS 也可以防止按钮重复点击_个人文章 - SegmentFault 思否
众所周知,函数节流(throttle)是 JS 中一个非常常见的优化手段,可以有效的避免函数过于频繁的执行。欢迎关注我的公众号:前端侦探举个例子:一个保存按钮,为了避免重复提交或者服务器考虑,往往需要
顺晟科技
2022-11-17 12:07:42
113
众所周知,函数节流(throttle)是 JS 中一个非常常见的优化手段,可以有效的避免函数过于频繁的执行。
欢迎关注我的公众号:前端侦探
举个例子:一个保存按钮,为了避免重复提交或者服务器考虑,往往需要对点击行为做一定的限制,比如只允许每300ms
提交一次,这时候我想大部分同学都会到网上直接拷贝一段throttle
函数,或者直接引用lodash
工具库
btn.addEventListener('click', _.throttle(save, 300))
其实除了 JS 方式, CSS 也可以非常轻易的实现这样一个功能,无需任何框架库,一起看看吧
CSS 实现和 JS 的思维不同,需要从另一个角度去看待这个问题。
比如这里的需要对点击事件进行限制,也就是禁用点击事件,想想有什么方式可以禁用事件,没错,就是pointer-events
;
然后是时间的限制,每次点击后需要自动禁用300ms
,时间过后重新恢复,那么,有什么特性和时间以及状态恢复有关呢?没错,就是animation
;
除此之外,还需要有触发时机,这里是点击行为,所以必然和伪类:active
有关联。
因此,综合分析,实现这样一个功能需要用到pointer-events
、animation
以及:active
,那么如何将这些思路串联起来呢?
思考3秒...
17
2022-11
15
2022-09
31
2021-08