前端如何优雅的处理重复点击

想必大家都遇到过重复点击及业务互斥的情况,一贯的习惯,可能是设置loading字段来做相应的限制,该方式在业务复杂的情况下,会需要大量的loading字段管理,很是不便。

针对这种情况,推荐大家使用一个小的工具库request-loading,该工具库可以在用户无感知的情况下防重复点击,在超长业务处理时,亦能弹出loading做等待提示。该工具业务简单,代码量少,大家也可以自行实现。

实现思路

  1. 用户点击"功能按钮",先弹一个透明遮罩层,将整个页面盖住,隔绝所有点击。
  2. 当功能异步处理时间少于loading阈值,则直接关闭遮罩层,用户无任何感知,十分友好。
  3. 当功能异步处理时间大于loading阈值,则展示loading图文,让用户感知到在处理业务中,给以友好的提示,当业务处理完时,关闭loading图文及遮罩层。
graph TD A[点击功能] --> B[弹出遮罩] B --> C{业务时长超出阈值} C -->|否| D[弹出loading] C -->|是| E[业务结束] D --> E E --> F[关闭loading及遮罩]

工具安装

查看地址

bash 复制代码
# 使用npm
npm i -S request-loading
# 使用yarn
yarn add request-loading

用法

ts 复制代码
// 需要引入全局样式
import Loading from 'request-loading'
import 'request-loading/dist/index.css'

Loading.show()

http.get('/user/info').finally(() => {
  Loading.hide()
})
相关推荐
Jave210814 分钟前
实现全局自定义loading指令
前端·vue.js
奔跑的呱呱牛18 分钟前
CSS Grid 布局参数详解(超细化版)+ 中文注释 Demo
前端·css·grid
木斯佳41 分钟前
前端八股文面经大全:影刀AI前端一面(2026-04-01)·面经深度解析
前端·人工智能·沙箱·tool·ai面经
小江的记录本1 小时前
【Linux】《Linux常用命令汇总表》
linux·运维·服务器·前端·windows·后端·macos
无人机9012 小时前
Delphi 网络编程实战:TIdTCPClient 与 TIdTCPServer 类深度解析
java·开发语言·前端
lUie INGA3 小时前
rust web框架actix和axum比较
前端·人工智能·rust
OPHKVPS3 小时前
VoidStealer新型窃密攻击:首例利用硬件断点绕过Chrome ABE防护,精准窃取v20_master_key
前端·chrome
gechunlian883 小时前
SpringBoot3+Springdoc:v3api-docs可以访问,html无法访问的解决方法
前端·html
驾驭人生4 小时前
ASP.NET Core 实现 SSE 服务器推送|生产级实战教程(含跨域 / Nginx / 前端完整代码)
服务器·前端·nginx
酉鬼女又兒4 小时前
零基础快速入门前端ES6 核心特性详解:Set 数据结构与对象增强写法(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯·es6