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

如何在 Element UI 中优雅地使用 `this.$loading` 显示和隐藏加载动画

如何在 Element UI 中优雅地使用 this.$loading 显示和隐藏加载动画

在现代 Web 应用开发中,用户体验至关重要。当执行耗时操作(如网络请求或数据处理)时,显示一个友好的加载动画可以让用户知道系统正在工作,而不是卡住了。Element UI 提供了一个非常方便的工具——this.$loading,用于显示全局或局部的加载动画。本文将详细介绍如何在 Vue 组件中使用 this.$loading 来显示和隐藏加载动画,并提供实用的代码示例。


1. 引言

在构建复杂的前端应用时,异步操作是不可避免的。无论是从服务器获取数据还是进行大量计算,都需要一些时间来完成。为了提升用户体验,我们通常会在这些操作期间显示一个加载动画。Element UI 的 this.$loading 工具可以帮助我们轻松实现这一目标。接下来,我们将详细介绍如何使用它。


2. 基本用法

显示加载动画

通过调用 this.$loading(options) 方法可以创建并显示加载动画。返回值是一个加载实例,可以通过该实例手动关闭加载动画。

let loadingInstance = this.$loading({lock: true, // 是否锁定屏幕text: '加载中...', // 显示的文本spinner: 'el-icon-loading', // 自定义加载图标background: 'rgba(0, 0, 0, 0.7)' // 背景遮罩颜色
});

隐藏加载动画

可以通过调用加载实例的 close() 方法来关闭加载动画。

loadingInstance.close();

3. 完整示例

以下是一个完整的示例,展示如何在 Vue 组件中使用 this.$loading 来显示和隐藏加载动画。

<template><div><el-button @click="startLoading">开始加载</el-button><el-button @click="stopLoading">停止加载</el-button></div>
</template><script>
export default {data() {return {loadingInstance: null // 存储加载实例};},methods: {startLoading() {// 显示加载动画this.loadingInstance = this.$loading({lock: true,text: '拼命加载中...',spinner: 'el-icon-loading',background: 'rgba(0, 0, 0, 0.7)'});},stopLoading() {// 隐藏加载动画if (this.loadingInstance) {this.loadingInstance.close();}}}
};
</script>

在这个示例中,我们创建了两个按钮:一个用于启动加载动画,另一个用于停止加载动画。点击“开始加载”按钮后,会显示一个带有自定义文本和图标的加载动画;点击“停止加载”按钮则会关闭该动画。


4. 关键点解析

(1) 参数配置

this.$loading 接受一个配置对象,常用的参数如下:

  • lock:是否锁定屏幕,防止用户交互。
  • text:加载提示文字。
  • spinner:自定义加载图标,默认为 el-icon-loading
  • background:背景遮罩的颜色,支持透明度设置。

(2) 自动关闭

如果需要自动关闭加载动画,可以结合 setTimeout 使用。例如:

startLoading() {this.loadingInstance = this.$loading({lock: true,text: '加载中...'});// 模拟异步操作后自动关闭setTimeout(() => {this.loadingInstance.close();}, 3000); // 3秒后自动关闭
}

(3) 局部加载

除了全局加载,还可以对某个 DOM 元素进行局部加载。只需在 options 中指定 target 即可。

let loadingInstance = this.$loading({target: document.querySelector('#local-element'), // 指定目标元素text: '局部加载中...'
});

5. 注意事项

避免重复创建

在调用 this.$loading 时,确保之前创建的加载实例已经关闭。否则可能会导致多个加载动画叠加。可以在显示新加载动画前检查是否存在旧实例,并手动关闭:

if (this.loadingInstance) {this.loadingInstance.close();
}

异步操作中的异常处理

在异步操作(如 API 请求)中使用加载动画时,务必在 try-catchfinally 中关闭加载动画,以防止因异常导致加载动画无法关闭。

async fetchData() {let loadingInstance = this.$loading({ text: '加载中...' });try {await someAsyncOperation(); // 模拟异步操作} catch (error) {console.error('请求失败', error);} finally {loadingInstance.close(); // 确保加载动画关闭}
}

样式覆盖

如果默认的加载样式不符合需求,可以通过 CSS 自定义样式。例如:

.el-loading-spinner .el-loading-text {font-size: 16px;color: #fff;
}

6. 总结

通过 this.$loading,我们可以轻松实现全局或局部的加载动画,从而提升用户体验。无论是简单的按钮点击还是复杂的异步操作,都可以灵活地应用这一功能。如果你正在寻找一种优雅的方式来管理加载状态,那么这篇文章提供的解决方案无疑是一个不错的选择。

希望本文能为你带来启发,并帮助你在实际开发中解决问题!如果有其他问题或想要了解更多优化技巧,请留言讨论。


关注我获取更多前端开发技巧和实战经验!


注:本文假设读者已经具备一定的 Vue.js 和 Element UI 基础知识。如果你对某个部分不太理解,欢迎留言讨论!


相关文章:

如何在 Element UI 中优雅地使用 `this.$loading` 显示和隐藏加载动画

如何在 Element UI 中优雅地使用 this.$loading 显示和隐藏加载动画 在现代 Web 应用开发中&#xff0c;用户体验至关重要。当执行耗时操作&#xff08;如网络请求或数据处理&#xff09;时&#xff0c;显示一个友好的加载动画可以让用户知道系统正在工作&#xff0c;而不是卡…...

大模型微调 - 自注意力机制

一.什么是自注意力机制 注意力机制&#xff08;Attention Mechanism&#xff09;是一种能够根据输入的相关性动态分配权重的机制&#xff0c;广泛应用于自然语言处理、计算机视觉等领域。其核心思想是&#xff1a;“让模型在处理当前元素时&#xff0c;关注与其最相关的其他部…...

TDengine 集群高可用方案设计(二)

四、TDengine 集群高可用方案设计 4.1 硬件与网络架构设计 服务器选型&#xff1a;选择配置高、稳定性强的服务器&#xff0c;如戴尔 PowerEdge R740xd、华为 RH2288H V5 等。以戴尔 PowerEdge R740xd 为例&#xff0c;它配备英特尔至强可扩展处理器&#xff0c;具备高性能计…...

【Langchain】RAG 优化:提高语义完整性、向量相关性、召回率--从字符分割到语义分块 (SemanticChunker)

RAG 优化&#xff1a;提高语义完整性、向量相关性、召回率–从字符分割到语义分块 (SemanticChunker) 背景&#xff1a;提升 RAG 检索质量 在构建基于知识库的问答系统&#xff08;RAG&#xff09;时&#xff0c;如何有效地将原始文档分割成合适的文本块&#xff08;Chunks&a…...

深入剖析扣子智能体的工作流与实战案例

前面我们已经初步带大家体验过扣子工作流&#xff0c;工作流程是 Coze 最为强大的功能之一&#xff0c;它如同扣子中蕴含的奇妙魔法工具&#xff0c;赋予我们的机器人处理极其复杂问题逻辑的能力。 这篇文章会带你更加深入地去理解并运用工作流解决实际问题 目录 一、工作流…...

C++----模拟实现string

模拟实现string&#xff0c;首先我们要知道成员变量有哪些&#xff1a; class _string{private:char* _str;size_t capacity;//空间有多大size_t size;//有效字符多少const static size_t npos;};const size_t _string::npos-1;//static在外面定义不需要带static&#xff0c;np…...

CodeMeter Runtime 安装失败排查与解决指南

CodeMeter Runtime 是威步提供的核心运行服务组件&#xff0c;用于加密授权的识别与管理。如果安装过程中出现异常或中断&#xff0c;常见原因包括系统冲突程序、数字签名校验失败、安全软件干扰或权限不足。 以下为推荐的完整排查步骤&#xff1a; 1. 检查并清理冲突程序或驱动…...

基于K8s日志审计实现攻击行为检测

K8s日志审计以一种事件溯源的方式完整记录了所有API Server的交互请求。当K8s集群遭受入侵时&#xff0c;安全管理员可以通过审计日志进行攻击溯源&#xff0c;通过分析攻击痕迹&#xff0c;找到攻击者的入侵行为并还原攻击者的攻击路径&#xff0c;修复安全问题。 在本篇文章中…...

【Linux网络编程】应用层协议HTTP(实现一个简单的http服务)

目录 前言 一&#xff0c;HTTP协议 1&#xff0c;认识URL 2&#xff0c;urlencode和urldecode 3&#xff0c;HTTP协议请求与响应格式 二&#xff0c;myhttp服务器端代码的编写 HTTP请求报文示例 HTTP应答报文示例 代码编写 网络通信模块 处理请求和发送应答模块 结…...

短视频+直播商城系统源码全解析:音视频流、商品组件逻辑剖析

时下&#xff0c;无论是依托私域流量运营的品牌方&#xff0c;还是追求用户粘性与转化率的内容创作者&#xff0c;搭建一套完整的短视频直播商城系统源码&#xff0c;已成为提升用户体验、增加商业变现能力的关键。本文将围绕三大核心模块——音视频流技术架构、商品组件设计、…...

STM32定时器---基本定时器

目录 一、定时器的概述 二、时基单元 三、基本定时器的的时序 &#xff08;1&#xff09;预分频器时序 &#xff08;2&#xff09;计数器时序 四、基本定时器的使用 一、定时器的概述 在没有定时器的时候&#xff0c;我们想要延时往往都是写一个Delay函数&#xff0c;里面…...

mysql快速在不同库中执行相同的sql

目录 背景 解决方案 方式一&#xff1a;利用变量拼接好sql&#xff0c;复制出来执行&#xff08;简单&#xff0c;推荐&#xff09; 方式二&#xff1a;使用存储过程和游标实现&#xff08;比较复杂&#xff0c;脚本需要拼接一个完整的&#xff0c;也比较麻烦&#xff0c;不…...

大模型微调 - transformer架构

什么是Transformer Transformer 架构是由 Vaswani 等人在 2017 年提出的一种深度学习模型架构&#xff0c;首次发表于论文《Attention is All You Need》中 Transformer 的结构 Transformer 编码器&#xff08;Encoder&#xff09; 解码器&#xff08;Decoder&#xff09; …...

【器件专题1——IGBT第1讲】IGBT:电力电子领域的 “万能开关”,如何撑起新能源时代?

一、IGBT 是什么&#xff1f;重新认识这个 “低调的电力心脏” 你可能没听过 IGBT&#xff0c;但一定用过它驱动的设备&#xff1a;家里的变频空调、路上的电动汽车、屋顶的光伏逆变器&#xff0c;甚至高铁和电网的核心部件里&#xff0c;都藏着这个 “电力电子开关的瑞士军刀”…...

文件IO(Java)

注&#xff1a;此博文为本人学习过程中的笔记 1.概念 狭义上的文件是指保存在硬盘上的文件&#xff0c;广义上指操作系统进行资源管理的一种机制&#xff0c;很多软件/硬件资源都可以抽象成文件&#xff0c;这里我们针对的是狭义上的文件。 在硬盘里还有文件夹&#xff0c;这…...

常见缓存淘汰算法(LRU、LFU、FIFO)的区别与实现

一、前言 缓存淘汰算法主要用于在内存资源有限的情况下&#xff0c;优化缓存空间的使用效率。以确保缓存系统在容量不足时能够智能地选择需要移除的数据。 二、LRU&#xff08;Least Recently Used&#xff09; 核心思想&#xff1a;淘汰最久未被访问的数据。实现方式&#x…...

Sentinel数据S2_SR_HARMONIZED连续云掩膜+中位数合成

在GEE中实现时&#xff0c;发现简单的QA60是无法去云的&#xff0c;最近S2地表反射率数据集又进行了更新&#xff0c;原有的属性集也进行了变化&#xff0c;现在的SR数据集名称是“S2_SR_HARMONIZED”。那么&#xff1a; 要想得到研究区无云的图像&#xff0c;可以参考执行以下…...

HTMLCSS模板实现水滴动画效果

.container 类&#xff1a;定义了页面的容器样式。 display: flex&#xff1a;使容器成为弹性容器&#xff0c;方便对其子元素进行布局。justify-content: center 和 align-items: center&#xff1a;分别使子元素在水平和垂直方向上居中对齐。min-height: 100vh&#xff1a;设…...

Cesium实现地形可视域分析

Cesium实现可视化分析 一、地形可视域主要实现技术(Ray + 地形碰撞检测) Cesium 本身的 Ray 类可以用来执行非常精确的射线检测,我们可以结合地形高度(sample)来逐点检测光线是否与 terrain 相交,从而判断是否可见。 1.1 优势 实时判断每条射线是否被 terrain 遮挡地形…...

前端如何获取文件的 Hash 值?多种方式详解、对比与实践指南

文章目录 前言一、Hash 值为何重要&#xff1f;二、Hash 值基础知识2.1 什么是 Hash&#xff1f;2.2 Hash 在前端的应用场景2.3 常见的 Hash 算法&#xff08;MD5、SHA 系列&#xff09; 三、前端获取文件 Hash 的常用方式3.1 使用 SparkMD5 计算 MD5 值3.2 使用 Web Crypto AP…...

【数据可视化艺术·应用篇】三维管线分析如何重构城市“生命线“管理?

在智慧城市、能源管理、工业4.0等领域的快速发展中&#xff0c;地下管线、工业管道、电力通信网络等“城市血管”的复杂性呈指数级增长。传统二维管理模式已难以应对跨层级、多维度、动态变化的管线管理需求。三维管线分析技术应运而生&#xff0c;成为破解这一难题的核心工具。…...

蓝桥杯 16.对局匹配

对局匹配 原题目链接 题目描述 小明喜欢在一个围棋网站上找别人在线对弈。这个网站上所有注册用户都有一个积分&#xff0c;代表他的围棋水平。 小明发现&#xff0c;网站的自动对局系统在匹配对手时&#xff0c;只会将积分差恰好是 K 的两名用户匹配在一起。如果两人分差小…...

【MinerU】:一款将PDF转化为机器可读格式的工具——RAG加强(Docker版本)

目录 创建容器 安装miniconda 安装mineru CPU运行 GPU加速 多卡问题 创建容器 构建Dockerfile文件 开启ssh服务&#xff0c;设置密码为1234等操作 # 使用官方 Ubuntu 24.04 镜像 FROM ubuntu:24.04# 安装基础工具和SSH服务 RUN apt-get update && \apt-get ins…...

DeepSeek回答过于笼统,提示词如何优化

针对DeepSeek回答过于笼统的问题&#xff0c;可通过以下方法优化&#xff0c;使输出更具体、详细&#xff1a; 一、优化提示词设计 明确具体要求 在提问中嵌入「背景限制示例」&#xff0c;例如&#xff1a; “作为跨境电商运营新手&#xff0c;请详细说明如何优化亚马逊产品标…...

C语言实现贪心算法

一、贪心算法核心思想 特征&#xff1a;在每一步选择中都采取当前状态下最优&#xff08;局部最优&#xff09;的选择&#xff0c;从而希望导致全局最优解 适用场景&#xff1a;需要满足贪心选择性质和最优子结构性质 二、经典贪心算法示例 1. 活动选择问题 目标&#xff1a…...

全球碳化硅晶片市场深度解析:技术迭代、产业重构与未来赛道争夺战(2025-2031)

一、行业全景&#xff1a;从“材料突破”到“能源革命”的核心引擎 碳化硅&#xff08;SiC&#xff09;作为第三代半导体材料的代表&#xff0c;凭借其宽禁带&#xff08;3.26eV&#xff09;、高临界击穿场强&#xff08;3MV/cm&#xff09;、高热导率&#xff08;4.9W/cmK&…...

FreeRTOS学习笔记【10】-----任务上下文切换

1 概念性内容 开机到调度需要经历的步骤有&#xff1a; 系统初始化任务创建启动调度器上下文切换时间分片任务执行 1.1 任务本质 FreeRTOS 的 任务&#xff08;Task&#xff09;本质上就是一个运行在任务自己的栈区中无限循环的函数 一段上下文&#xff08;context&#x…...

Appium自动化开发环境搭建

自动化 文章目录 自动化前言 前言 Appium是一款开源工具&#xff0c;用于自动化iOS、Android和Windows桌面平台上的本地、移动web和混合应用程序。原生应用是指那些使用iOS、Android或Windows sdk编写的应用。移动网页应用是通过移动浏览器访问的网页应用(appum支持iOS和Chrom…...

C++学习-入门到精通-【1】C++编程入门,输入/输出和运算符

C学习-入门到精通-【1】C编程入门&#xff0c;输入/输出和运算符 C编程入门&#xff0c;输入/输出和运算符 C学习-入门到精通-【1】C编程入门&#xff0c;输入/输出和运算符第一个C程序&#xff1a;输出一行文本算术运算 第一个C程序&#xff1a;输出一行文本 // 文本打印程序…...

UOJ 228 基础数据结构练习题 Solution

Description 给定序列 a ( a 1 , a 2 , ⋯ , a n ) a(a_1,a_2,\cdots,a_n) a(a1​,a2​,⋯,an​)&#xff0c;有 m m m 个操作分三种&#xff1a; add ⁡ ( l , r , k ) \operatorname{add}(l,r,k) add(l,r,k)&#xff1a;对每个 i ∈ [ l , r ] i\in[l,r] i∈[l,r] 执行 …...