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

【手搓一个原生全局loading组件解决页面闪烁问题】

页面闪烁效果1
页面闪烁效果2

封装一个全局loading组件

class GlobalLoading extends HTMLElement {constructor() {super();this.attachShadow({ mode: 'open' });}connectedCallback() {this.render();this.init();}render() {this.shadowRoot.innerHTML = `<style>.loading-overlay {position: fixed;top: 0;left: 0;width: 100%;height: 100%;background-color: rgba(255, 255, 255, 0.9);display: flex;justify-content: center;align-items: center;z-index: 9999;}.loading-spinner {border: 4px solid #f3f3f3;border-top: 4px solid #3498db;border-radius: 50%;width: 40px;height: 40px;animation: spin 1s linear infinite;}@keyframes spin {0% { transform: rotate(0deg); }100% { transform: rotate(360deg); }}</style><div class="loading-overlay"><div class="loading-spinner"></div></div>`;}init() {window.addEventListener('load', () => {setTimeout(() => {this.shadowRoot.querySelector('.loading-overlay').style.display = 'none';}, 500); // 延时 500 毫秒});}
}customElements.define('global-loading', GlobalLoading);

引入全局 loading 组件

<!-- 引入全局 loading 组件 -->
<script src="./components/global-loading.js" defer></script>

使用全局loading组件

<!-- 使用全局 loading 组件 -->
<global-loading></global-loading>
image-20250531143603301

相关文章:

  • python打卡训练营打卡记录day41
  • 机器学习知识图谱——K-means++聚类算法
  • AnyTXT Searcher 文档内容搜索工具 v1.3.2034 官方版
  • MySQL--day10--数据处理之增删改
  • 《管理经济》期末复习题(2)
  • 智能测试新范式:GenAI 与 Playwright MCP 如何重塑 QA 流程
  • 学术合作交流
  • Dest建筑能耗模拟仿真功能简介
  • InfluxQL 数据分析实战:聚合、过滤与关联查询全解析
  • 【Linux】mmap文件内存映射
  • QuickJS 在生物化学计算中的应用
  • 5.1 初探大数据流式处理
  • 云原生安全基石:Kubernetes 核心概念与安全实践指南
  • 【harbor】--基础使用
  • 【android bluetooth 案例分析 04】【Carplay 详解 2】【Carplay 连接之手机主动连车机】
  • 汽车电子笔记之:有关汽车电子AUTOSAR的一些名词解释
  • 调用蓝耘Maas平台大模型API打造个人AI助理实战
  • WEB3——简易NFT铸造平台之nft.storage
  • 谷歌Stitch:AI赋能UI设计,免费高效新利器
  • 每日Prompt:隐形人
  • 有个新网站专门做外贸的叫什么/个人网站制作软件
  • 石龙网站建设/刷粉网站推广免费
  • 高端服装网站/php视频转码
  • 网页设计模板之家/山西seo优化公司
  • 东莞商城网站建设/中国网络营销公司
  • 建筑网站开发设计/百度竞价推广有哪些优势