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;
相关文章:
React+Antd全局加载遮罩工具
下面是全局加载遮罩工具,功能:提供show和showWithDelay/hide方法用于显示/延时显示/隐藏遮罩,它还提供loading属性返回是否正在loading。通常用于耗时较长的操作,比如远端api调用。 如何用它,下面是个例子,…...
Qt OpenGL 光照实现
Qt 中使用 OpenGL 实现光照效果主要基于 OpenGL 的光照模型和着色器编程。以下是 Qt OpenGL 光照实现的核心原理: 一. 光照模型基础 OpenGL 使用 Phong 光照模型,包含三个主要光照分量: 环境光(Ambient):场景中的基础光照,没有方向性 漫反射光(Diffuse):与表面法线和光…...

智汇云舟携最新无人机2D地图快速重建技术亮相广西国际矿业展览会
5月22至25日,广西国际矿业展览会(以下简称 “矿业展”)在南宁国际会展中心成功举办。智汇云舟与合作伙伴广西空驭数智信息技术有限公司携无人机 2D地图快速重建技术,以及视频孪生智慧矿山解决方案参会,为矿山行业数字化…...
Rust: CString、CStr和String、str
在FFI与C交互中,少不了与C中字符串交互。在Rust中,有 各种String存在的意义: OsString:因为要与操作系统等复杂的世界交互; 因为Rust世界中的Strings 始终是有效的 UTF-8。对于非 UTF-8 字符串,可以用到OsString。 CSt…...

力扣每日一题——连接两棵树后最大目标节点数目 ||
目录 题目链接:3373. 连接两棵树后最大目标节点数目 II - 力扣(LeetCode) 题目描述 解法一:双树贡献分离法 Java写法: C写法: 运行时间 时间复杂度和空间复杂度 总结 题目链接:…...

【学习笔记】Sparse Crosscoders for Cross-Layer Features and Model Diffing
Sparse Crosscoders for Cross-Layer Features and Model Diffing Abstract 本说明介绍了稀疏跨编码器(sparse crosscoders),它是一种稀疏自编码器(sparse autoencoders)或transcoders的变体,旨在用于理解叠加中的模型结构。SAEs是在单一层中编码和预测…...

VSCode无法转到定义python源码(ctrl加单击不跳转)
已经尝试的方案: 1.确保对应python环境正确激活 在 VSCode 中,打开命令面板(CtrlShiftP),输入并选择 Python: Select Interpreter,然后从列表中选择正确的 Python 解释器。 2.重新卸载Python插件再重新安装…...

【华为战报】4月、5月 HCIP考试战报!
了解更多往期考试→点 【考试战报】 华为认证 HCIP 4、5月微思 | HCIP 考试战报 学员成绩单 华为认证 最新开班 厦门面授 全国直播 新生代网工必看:华为模拟器eNSP安装教程(附下载链接)...
开发指南120-表格(el-table)斑马纹
el-table实现斑马纹简单否,看起来很简单,网上给的例子都是加stripe,例如 <el-table :data"tableData" stripe>连官网上的例子都是这样。然并卵。也许是版本问题。这么写,怎么折腾都没有效果。 必须这样写才行 …...
数字化转型全场景安全解析:从产品到管理的防线构建与实施要点
在数字化转型中,安全已从“可选配置” 升级为 “必需底座”,贯穿于产品生命周期、生产过程、供应链及管理决策全场景。以下从南京市场景清单出发,结合技术实践与政策要求,分析安全在各核心场景中的具体内涵与实施要点:…...

AIGC工具平台-GPT-SoVITS-v4-TTS音频推理克隆
声音克隆与语音合成的结合,是近年来生成式AI在多模态方向上的重要落地场景之一。随着预训练模型能力的增强,结合语音识别、音素映射与TTS合成的端到端系统成为初学者可以上手实践的全流程方案。 围绕 GPT-SoVITS-v4-TTS 模块,介绍了其在整合…...

el-table配置表头固定而且高度变化
根据官网提示只要在 el-table 元素中定义了 height 属性,即可实现固定表头的表格,而不需要额外的代码。 如果你想既要固定表头,又要下方表格高度自适应,可以设置为 height"100%" : 然后外层设置scroll:...

设计模式——组合设计模式(结构型)
摘要 组合设计模式是一种结构型设计模式,用于将对象组合成树形结构以表示“部分-整体”的层次结构,使客户端对单个对象和组合对象具有一致的访问方式。它包含抽象组件、叶子节点和组合节点,具有统一处理、支持递归结构和易扩展等优点&#x…...
PostgreSQL 在生物信息学中的应用
PostgreSQL(简称PG)是一种强大的开源关系型数据库管理系统,因其高可靠性、扩展性和支持复杂查询的特性,在生物信息学领域得到广泛应用。以下是其核心应用场景及优势分析: 一、生物数据存储与管理 生物信息学涉及海量…...

EMO2:基于末端执行器引导的音频驱动虚拟形象视频生成
今天带来EMO2(全称End-Effector Guided Audio-Driven Avatar Video Generation)是阿里巴巴智能计算研究院研发的创新型音频驱动视频生成技术。该技术通过结合音频输入和静态人像照片,生成高度逼真且富有表现力的动态视频内容,值得…...
计算机总线技术深度解析:从系统架构到前沿演进
计算机系统中的总线是连接多个部件的信息传输线,是各部件间传输信息的公共通道。以下将从总线的定义、功能、分类、性能指标等方面进行详细介绍: 一、总线的定义与功能 1.定义:总线是一组能为多个部件分时共享的公共信息传送线路࿰…...

Python打卡训练营Day43
DAY 43 复习日 作业: kaggle找到一个图像数据集,用cnn网络进行训练并且用grad-cam做可视化 数据集地址:Lung Nodule Malignancy 肺结核良恶性判断 进阶:并拆分成多个文件 import os import pandas as pd import numpy as np from…...

PHP7+MySQL5.6 查立得轻量级公交查询系统
# PHP7MySQL5.6 查立得轻量级公交查询系统 ## 系统简介 本系统是一个基于PHP7和MySQL5.6的轻量级公交查询系统(40KB级),支持线路查询、站点查询和换乘查询功能。系统采用原生PHPMySQL开发,无需第三方框架,适合手机端访问。 首发版本&#x…...

如何做好一个决策:基于 Excel的决策树+敏感性分析应用(针对多个变量)
本文是对《如何做好一个决策:基于 Excel的决策树+敏感性分析应用》一文的补充。 示例背景 决策问题:是否开发新产品? 关键变量: 开发成本(B2):$500K, $700K, $1M高需求概率(B4):30%, 50%, 70%高需求收入(C4...

Azure DevOps 管道部署系列之一本地服务器
Azure DevOps 是一个帮助改进 SDLC(软件开发生命周期)的平台。 在本文中,我们将使用 Azure Pipelines 创建自动化部署。 Azure DevOps 团队将 Azure Pipelines 定义为“使用 CI/CD 构建、测试和部署,适用于任何语言、平台和云平台”。 在这里,我将解释如何在 Azure Dev…...
DeepSeekMath:突破开放式语言模型中数学推理能力的极限
摘要 由于数学推理具有复杂且结构化的特性,这对语言模型构成了重大挑战。在本文中,我们介绍了 DeepSeekMath 7B 模型,该模型在 DeepSeek-Coder-Base-v1.5 7B 模型的基础上,使用从 Common Crawl 获取的 1200 亿个与数学相关的标记,以及自然语言和代码数据继续进行预训练。…...
QT 5.15.2 程序中文乱码
1. 在.pro文件中添加: msvc { QMAKE_CXXFLAGS /source-charset:utf-8 /execution-charset:utf-8 }备注:.pro文件只有在选择 qmake 方式才会生成。 [Cmake 只会生成 CMakeLists.txt 文件] 2. 在文件首部增加以下程序行 #pragma execution_character_s…...

Celery简介
一、什么是异步任务队列 异步任务队列是指一种用于管理和调度异步执行任务的机制。具体来说,它允许将任务放入队列中,然后由后台进程异步处理这些任务,而不会阻塞主线程的执行。这种设计使得系统能够高效地处理耗时操作,同时保持…...
StarRocks物化视图
## 引言 在大数据时代,企业对实时数据分析的需求日益增长,而传统OLAP系统在处理复杂查询时往往面临性能瓶颈。StarRocks作为新一代极速全场景MPP分析型数据库,通过其独特的**物化视图(Materialized View, MV)**技术&a…...
vue2源码解析——响应式原理
文章目录 引言数据劫持收集依赖数组处理渲染watchervue3中的响应式 引言 vue的设计思想是数据双向绑定、数据与UI自动同步,即数据驱动视图。 为什么会这样呢?这就不得不提vue的响应式原理了,在使用vue的过程中,我被vue的响应式设…...

基于 GitLab CI + Inno Setup 实现 Windows 程序自动化打包发布方案
在 Windows 桌面应用开发中,实现自动化构建与打包发布是一项非常实用的工程实践。本文以我在开发PackTes项目时的为例,介绍如何通过 GitLab CI 配合 Inno Setup、批处理脚本、Qt 构建工具,实现版本化打包并发布到共享目录的完整流程。 项目地…...
做好 4个基本动作,拦住性能优化改坏原功能的bug
缺陷分析 “小李,202504300989这个现场缺陷你负责测试漏测分析,要求用5why方法找到漏测根因,根据找到的根因制定改进措施。你今天下班前完成,完成后立刻通知我,质量部现在每天都在催现场缺陷分析结果。”周二刚上班&a…...
【HarmonyOS 5】针对 Harmony-Cordova 性能优化,涵盖原生插件开发、线程管理和资源加载等关键场景
1. 原生图片处理插件(Java) package com.example.plugin; import ohos.media.image.ImageSource; import ohos.media.image.PixelMap; import ohos.app.Context; public class ImageProcessor { private final Context context; public ImagePro…...
零基础认知企业级数据分析平台如何落实数据建模(GAI)
理解数据建模的基本概念 数据建模是将业务需求转化为数据结构和关系的过程,核心目标是构建可支撑分析、预测或决策的数据模型。零基础需从以下维度入手: 业务理解:明确业务问题(如销售预测、用户分群),与…...

web架构2------(nginx多站点配置,include配置文件,日志,basic认证,ssl认证)
一.前言 前面我们介绍了一下nginx的安装和基础配置,今天继续来深入讲解一下nginx的其他配置 二.nginx多站点配置 一个nginx上可以运行多个网站。有多种方式: http:// ip/域名 端口 URI 其中,ip/域名变了,那么网站入口就变了…...