当前位置: 首页 > news >正文

节流还在用JS吗?CSS也可以实现哦

函数节流是一个我们在项目开发中常用的优化手段,可以有效避免函数过于频繁的执行。一般函数节流用在scroll页面滚动,鼠标移动等。

为什么需要节流呢,因为触发一次事件就会执行一次事件,这样就形成了大量操作dom,会出现卡顿的情况。

一、传统JS节流实现方式

   /* 1.时间戳实现 */function throttle(func, delay) {let prev = 0return function(...args){let now = new Date()if(now - prev > delay){prev = new Date()func.apply(this, args)}}}/* 定时器实现 */function throttle(func, delay) {let timer = nullreturn function(...args) {if(!timer){timer = setTimeout(() => {timer = nullfunc.apply(this, args)},delay)}}}

二、CSS实现
1.实现思路

我们可以使用css的pointer-events禁用点击事件对事件进行控制。
使用animation设置禁用时间,对时间进行限制。
使用:active点击行为作为触发时机

可以这样理解,一个CSS动画从禁用可点击的变化,每次点击时让这个动画重新执行一遍,在整个执行过程设置的时间范围内一直处于禁用的状态,这是不是就有点像节流的功能。

2.具体实现
假设一个按钮,连续点击按钮就会一直触发事件。

<button onclick="console.log('111')">点击按钮</button>

在这里插入图片描述
使用pointer-events实现一个动画,从禁用到可点击。

 @keyframes throttle {from {color: green;pointer-events: none;}to {color: black;pointer-events: all;}}button {animation: throttle 3s step-end forwards;}button:active {animation: none;}

在这里插入图片描述

http://www.lryc.cn/news/41289.html

相关文章:

  • 带你看看 TypeScript 5.0 的新特性
  • C语言预处理条件语句的 与或运算
  • 从零实现深度学习框架——学习率调整策略介绍
  • 系统架构:经典三层架构
  • 数据结构--二叉树
  • Keil5安装和使用小记
  • 多机器人集群网络通信协议分析
  • 【PyTorch】手把手带你快速搭建PyTorch神经网络
  • 【完整代码】用HTML/CSS制作一个美观的个人简介网页
  • Java分布式事务(九)
  • 基于深度学习的动物识别系统(YOLOv5清新界面版,Python代码)
  • K8S集群之-ETCD集群监控
  • 一文弄懂熵、交叉熵和kl散度(相对熵)
  • 10从零开始学Java之开发Java必备软件Intellij idea的安装配置与使用
  • 04 - 进程参数编程
  • 【python进阶】你真的懂元组吗?不仅是“不可变的列表”
  • 《C++ Primer Plus》(第6版)第13章编程练习
  • 【多线程】多线程案例
  • 【IoT】嵌入式驱动开发:IIC子系统
  • DJ2-4 进程同步(第一节课)
  • AI独立开发者:一周涨粉8万赚2W美元;推特#HustleGPT GPT-4创业挑战;即刻#AIHackathon创业者在行动 | ShowMeAI周刊
  • 不要迷信 QUIC
  • 【28】Verilog进阶 - RAM的实现
  • 【MySQL】聚合查询
  • 初时STM32单片机
  • debian部署docker(傻瓜式)
  • JS判断是否为base64字符串如何转换为图片src格式
  • 【SpringMVC】SpringMVC方式,向作用域对象共享数据(ModelAndView、Model、map、ModelMap)
  • 本科课程【移动互联网应用开发(Android开发)】实验3 - Activity及数据存储
  • 为何在 node 项目中使用固定版本号,而不使用 ~、^?