React+Antd全局加载遮罩工具

下面是全局加载遮罩工具,功能:提供show和showWithDelay/hide方法用于显示/延时显示/隐藏遮罩,它还提供loading属性返回是否正在loading。通常用于耗时较长的操作,比如远端api调用。

如何用它,下面是个例子,这个是全局的postAction:

import loadingMask from './loadingMask';
...
// 设置延迟显示加载遮罩(1秒后显示)loadingMask.showWithDelay('请求处理中,请稍候...', 1000);return axios({url: url,method: 'post',data: parameter,headers: { ...signHeader, ...config.headers },...config}).then(res => {// 请求完成后隐藏加载遮罩loadingMask.hide();return handleResponse(res);}).catch(err => {// 请求出错后隐藏加载遮罩loadingMask.hide();return handleError(err);});

如果想实时获得它的loading属性呢?这时候要订阅它的状态变化:

const [loading, setLoading] = useState(loadingMask.loading);
// 订阅 loadingMask 的 loading 状态变化useEffect(() => {// 订阅 loading 状态变化const unsubscribe = loadingMask.subscribeToLoading(setLoading);// 组件卸载时取消订阅return unsubscribe;}, []);...<Buttonblocktype='submit'color='primary'loading={loading}>删除选中记录</Button>

这时候loadingMask的loading状态变化会立即返回到setLoading,也就会引导起button的重新渲染。

组件代码如下:

import React from 'react';
import { createRoot } from 'react-dom/client';
import { Mask, SpinLoading } from 'antd-mobile';
import styled from 'styled-components';const LoadingContainer = styled.div`display: flex;flex-direction: column;align-items: center;justify-content: center;position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);color: #ffffff;
`;const LoadingText = styled.div`margin-top: 12px;font-size: 14px;
`;/*** 全局加载遮罩工具* 用于在长时间请求时显示加载遮罩*/
class LoadingMask {constructor() {this.container = null;this.root = null;this.visible = false;this.timeoutId = null;this.loadingText = '正在加载,请稍候...';this._loading = false; // 添加内部 loading 状态this._listeners = []; // 添加监听器数组this.init();}/*** 初始化加载遮罩容器*/init() {// 创建容器元素this.container = document.createElement('div');this.container.id = 'global-loading-mask-container';document.body.appendChild(this.container);// 创建React 18的rootthis.root = createRoot(this.container);// 初始渲染this.render();}/*** 渲染加载遮罩*/render() {if (!this.root) {this.init();return;}this.root.render(<Mask opacity={0.7} visible={this.visible}><LoadingContainer><SpinLoading color='white' style={{ '--size': '48px' }} /><LoadingText>{this.loadingText}</LoadingText></LoadingContainer></Mask>);}/*** 显示加载遮罩* @param {string} text - 加载提示文本*/show(text) {this.loadingText = text || '正在加载,请稍候...';this.visible = true;this._setLoading(true); // 使用新方法设置 loading 状态this.render();}/*** 隐藏加载遮罩*/hide() {this.visible = false;this._setLoading(false); // 使用新方法设置 loading 状态this.render();// 清除定时器if (this.timeoutId) {clearTimeout(this.timeoutId);this.timeoutId = null;}}/*** 设置延迟显示加载遮罩* @param {string} text - 加载提示文本* @param {number} delay - 延迟时间(毫秒)*/showWithDelay(text, delay = 1000) {// 清除之前的定时器if (this.timeoutId) {clearTimeout(this.timeoutId);}// 立即设置 loading 状态为 truethis.loadingText = text || '正在加载,请稍候...';this._setLoading(true); // 使用新方法设置 loading 状态// 设置新的定时器,只延迟显示遮罩this.timeoutId = setTimeout(() => {this.visible = true;this.render();}, delay);}// 添加设置 loading 状态的方法,并通知监听器_setLoading(value) {if (this._loading !== value) {this._loading = value;// 通知所有监听器this._listeners.forEach(listener => listener(value));}};// 添加订阅方法subscribeToLoading(callback) {this._listeners.push(callback);// 立即通知当前状态callback(this._loading);// 返回取消订阅的函数return () => {this._listeners = this._listeners.filter(cb => cb !== callback);};};
}// 创建单例实例
const loadingMask = new LoadingMask();// 添加 loading 属性的 getter
Object.defineProperty(loadingMask, 'loading', {get: function() {return this._loading;}
});export default loadingMask;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/diannao/84868.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【机器学习基础】机器学习入门核心算法:GBDT(Gradient Boosting Decision Tree)

机器学习入门核心算法&#xff1a;GBDT&#xff08;Gradient Boosting Decision Tree&#xff09; 1. 算法逻辑2. 算法原理与数学推导2.1 目标函数2.2 负梯度计算2.3 决策树拟合2.4 叶子权重计算2.5 模型更新 3. 模型评估评估指标防止过拟合 4. 应用案例4.1 金融风控4.2 推荐系…

水墨色调中国风PPT模版分享

水墨色调中国风PPT模版分享&#xff1a;水墨中国风PPT模版https://pan.quark.cn/s/4368c537b1d2 第一套PPT模版​&#xff1a;主题是“爱莲说”&#xff0c;水墨风格封面。核心视觉是绿色莲蓬、白鹤、红色印章&#xff0c;文字有“爱莲说”等。适用文学或传统文化类演示。 ​第…

PBX、IP PBX、FXO 、FXS 、VOIP、SIP 的概念解析以及关系

PBX&#xff08;Private Branch Exchange&#xff09; 概念 &#xff1a;PBX 是专用交换机&#xff0c;是一种在企业或组织内部使用的电话交换系统。它允许内部用户之间以及内部用户与外部公共电话网络&#xff08;PSTN&#xff09;之间进行通信。例如&#xff0c;在一个大型企…

LabVIEW双光子荧光成像软件开发

双光子荧光成像技术在抑郁小鼠脑内丙二醛&#xff08;MDA&#xff09;和甲醛&#xff08;FA&#xff09;检测中的软件开发&#xff0c;基于 LabVIEW 平台构建从硬件控制、数据采集到图像处理的全流程系统。结合 5734 FPGA 实现实时图像处理&#xff0c;突出双光子成像的深度开发…

OSI模型中的网络协议

一、电子邮件协议&#xff1a;从SMTP到MIME的扩展 电子邮件系统的核心协议包括SMTP&#xff08;Simple Mail Transfer Protocol&#xff09;、POP3&#xff08;Post Office Protocol&#xff09;和IMAP&#xff08;Internet Message Access Protocol&#xff09;&#xff0c;但…

流程自动化引擎:让业务自己奔跑

在当今竞争激烈的商业环境中&#xff0c;企业面临着快速变化的市场需求、日益复杂的业务流程以及不断增长的运营成本。如何优化业务流程、提升效率并降低成本&#xff0c;成为企业持续发展的关键问题。 流程自动化引擎&#xff08;Process Automation Engine&#xff09;作为一…

DNS解析过程以及使用的协议名称

DNS&#xff08;Domain Name System 域名系统&#xff09;解析是一个分层查询的过程 1.本地缓存查询阶段 先检查浏览器自身的DNS缓存 接着检查操作系统的DNS缓存 最后检查本地 hosts 文件 2.本地DNS服务器查询阶段 先向本地DNS服务器查询&#xff0c;协议是 DNS over UDP&a…

思澈科技助力Keep Watch Pilot 1:重新定义智能运动手表体验

——以创新芯片技术&#xff0c;打造长续航、高性能的随身运动教练 作为智能穿戴领域的核心技术支持者&#xff0c;思澈科技携手Keep共同推出全新智能运动手表Keep Watch Pilot 1。该产品搭载思澈科技自主研发的SF32LB557芯片&#xff0c;在高性能显示、超长续航与精准运动监测…

github actions入门指南

GitHub Actions 是 GitHub 提供的持续集成和持续交付&#xff08;CI/CD&#xff09;平台&#xff0c;允许开发者自动化软件工作流程&#xff08;如构建、测试、部署&#xff09;。以下是详细介绍&#xff1a; 一、核心概念 Workflow&#xff08;工作流程&#xff09; 持续集成的…

Pytorch中一些重要的经典操作和简单讲解

Pytorch中一些重要的经典操作和简单讲解&#xff1a; 形状变换操作 reshape() / view() import torchx torch.randn(2, 3, 4) print(f"原始形状: {x.shape}")# reshape可以处理非连续张量 y x.reshape(6, 4) print(f"reshape后: {y.shape}")# view要求…

ubuntu下nginx

我用的是ubuntu22 配置文件的准确位置 静态网页的存放位置 放大看到在静态文件部署的配置路径 该路径下面有一个default文件查看 针对上图的解析如下&#xff1a; 找到root /var/www/html 我尝试把自己的一个index文件设置为默认&#xff0c;复制到/var/www/html下 ctrl加…

Git使用手册保姆级教程

Git 使用手册 一、Git 简介与安装 什么是Git&#xff1f; • Git 是一个分布式版本控制系统&#xff0c;用于跟踪文件变化&#xff0c;支持多人协作开发。 安装步骤 • Windows&#xff1a;通过 Git官网 下载安装包&#xff0c;按默认配置安装即可。 • macOS&#xff1a…

k8s Headless Service

Kubernetes 无头服务&#xff08;Headless Service&#xff09;配置与使用场景 1.无头服务概述 无头服务&#xff08;Headless Service&#xff09;是 Kubernetes 中的一种特殊服务类型&#xff0c;它**不分配集群 IP&#xff08;ClusterIP&#xff09;&#xff0c;而是直接暴露…

基本面高股息策略

策略概述 一种基于基本面高股息策略的投资策略,主要通过Python在聚宽平台上实现。该策略的核心思想是通过筛选出具有优质基本面和高股息率的股票进行投资,以期获得稳定的长期回报。策略包括以下几个主要步骤: 1. 初始化与参数设置:定义策略的基本参数和回测设置。 2. 每日…

GaussDB资源冻结与解冻:精细化资源管理的实践与策略

GaussDB资源冻结与解冻&#xff1a;精细化资源管理的实践与策略 引言 在云计算环境中&#xff0c;数据库资源的动态调配能力直接影响业务成本与稳定性。华为云GaussDB作为新一代分布式数据库&#xff0c;通过​​资源冻结&#xff08;Resource Quota Freeze&#xff09;​​与…

设计模式24——访问者模式

写文章的初心主要是用来帮助自己快速的回忆这个模式该怎么用&#xff0c;主要是下面的UML图可以起到大作用&#xff0c;在你学习过一遍以后可能会遗忘&#xff0c;忘记了不要紧&#xff0c;只要看一眼UML图就能想起来了。同时也请大家多多指教。 访问者模式&#xff08;Visito…

cuda编程笔记(2)--传递参数、设备属性

以下是最简单的带参数的核函数使用过程&#xff1a; #include<iostream> #include<cstdio> #include "cuda_runtime.h" #include "device_launch_parameters.h" __global__ void add(int a,int b,int *c) {*c a b; } int main() {int c;int…

C# WinForm应用程序多语言实现全面指南

目录 引言 一、多语言实现基础概念 1.1 多语言实现的核心原理 1.2 .NET本地化支持机制 二、基于XML的多语言实现方案 2.1 方案概述 2.2 XML文件结构示例 2.3 实现步骤 2.4 优缺点分析 三、基于.resx资源文件的多语言实现 3.1 方案概述 3.2 实现步骤 3.3 资源文件结…

Python爬虫实战:研究Playwright框架相关技术

1 引言 1.1 研究背景与意义 网络爬虫作为一种自动获取互联网信息的技术,在数据采集、信息监测、竞争情报等领域具有广泛应用。随着 Web 技术的发展,越来越多的网站采用 JavaScript 动态渲染技术,传统爬虫工具难以有效获取完整的页面内容。Playwright 作为新一代自动化测试…

中企出海大会|打造全球化云计算一张网,云网络助力中企出海和AI创新

全球化是阿里云的长期战略&#xff0c;未来阿里云将持续加大云和 AI 基础设施建设投入。首先是加速打造全球化的云计算网络&#xff0c;一张具备 AI技术服务能力和全球竞争力的云计算网络是阿里云的长期目标。 —— 阿里巴巴集团 CEO、阿里云智能集团董事长兼 CEO 吴泳铭 5 月 …