【CSS节流】实现防止按钮重复点击

众所周知,函数节流(throttle)是 JS 中一个非常常见的优化手段,可以有效的避免函数过于频繁的执行。

举例:在JavaScript中,可以使用节流(throttling)来控制事件的触发频率,以确保在一定时间内只执行一次相应的操作。对于保存按钮的点击行为,可以使用节流函数来确保在一定时间内只允许提交一次。

以下是使用js进行节流的方式:

javascript 复制代码
function throttle(func, delay) {
  let canRun = true;
  return function() {
    if (canRun) {
      func.apply(this, arguments);
      canRun = false;
      setTimeout(() => {
        canRun = true;
      }, delay);
    }
  };
}

// 模拟一个保存操作的函数
function saveData() {
  console.log("数据已保存");
}

// 创建节流函数
var throttledSave = throttle(saveData, 300); // 300ms为节流的时间间隔

// 绑定按钮点击事件
document.getElementById('saveBtn').addEventListener('click', throttledSave);

其实除了 JS 方式, CSS 也可以非常轻易的实现这样一个功能,无需任何框架库,一起看看吧!

一、CSS 实现思路分析

CSS 实现和 JS 的思维不同,需要从另一个角度去看待这个问题。

比如这里需要对点击事件进行限制,可以使用pointer-events;

然后是时间的限制,每次点击后需要自动禁用300ms,可以使用animation;

除此之外,还需要有点击行为,所以必然和伪类:active有关联。

二、具体实现:CSS 动画的精准控制

假设有一个按钮,绑定了一个点击事件,这时连续点击按钮就会不断地触发:

html 复制代码
<button onclick="console.log('保存')">保存</button>

完整代码如下,很好地限制了点击频率:

css 复制代码
button{
  /*动画缓动函数:设置成了step-end阶梯曲线,它可以很方便的控制pointer-events的变化时间点。*/
  animation: throttle 2s step-end forwards;
}

button:active{
  animation: none;
}

@keyframes throttle {
  from {
    pointer-events: none;
  }
  to {
    pointer-events: all;
  }
}

完成~

相关推荐
发现一只大呆瓜几秒前
React-手把手带你实现 Keep-Alive 效果
前端·react.js·面试
酉鬼女又兒22 分钟前
入门前端CSS 媒体查询全解析:从入门到精通,打造完美响应式布局(可用于备赛蓝桥杯Web应用开发)
前端·css·职场和发展·蓝桥杯·前端框架·html5·媒体
Dxy123931021631 分钟前
HTML常用标签详解
前端·html
毛骗导演33 分钟前
@tencent-weixin/openclaw-weixin 插件深度解析(一):认证与会话管理机制
前端·架构
wefly201740 分钟前
告别本地环境!m3u8live.cn一键实现 M3U8 链接预览与调试
前端·后端·python·音视频·m3u8·前端开发工具
SuperEugene43 分钟前
前端 console 日志规范实战:高效调试 / 垃圾 log 清理与线上安全避坑|编码语法规范篇
开发语言·前端·javascript·vue.js·安全
发现一只大呆瓜1 小时前
Vue - @ 事件指南:原生 / 内置 / 自定义事件全解析
前端·vue.js·面试
庄小焱1 小时前
React——React基础语法(1)
前端·javascript·vue.js
pingan87871 小时前
试试 docx.js 一键生成 Word 文档,效果很不错
开发语言·前端·javascript·ecmascript·word
张一凡932 小时前
重新理解 React 状态管理:用类的方式思考业务
前端·react.js