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

Vue3封装全局插件

定义一个全局加载组件

一、首先定义dom元素

定义一个index.vue文件

<template><div class="loading">loading...</div>
</template>
<script setup lang="ts"></script>
<style scoped>
.loading {display: flex;align-items: center;justify-content: center;font-size: 30px;color: #fff;background: rgba(0, 0, 0, 0.8);height: 100vh;
}
</style>

第二步给dom元素添加,控制显示的开关和方法,然后通过defineExpose暴露出去

<script setup lang="ts">
import { ref } from "vue"
const isShow = ref<boolean>(false);
const show = () => {isShow.value = true
}
const hide = () => {isShow.value = false
}
defineExpose({isShow,show,hide
})
</script>
二、把组件渲染到全局

定义一个index.ts把组件暴露出去

createVNode创建虚拟节点,render把节点渲染到body,然后创建一个全局变量方便操作$Loading

import type { App, VNode } from "vue"
import { createVNode, render } from 'vue'
import loading from './index.vue'
export default {install(app: App) {const Vnode: VNode = createVNode(loading);render(Vnode, document.body)app.config.globalProperties.$Loading = {show: Vnode.component?.exposed?.show,hide: Vnode.component?.exposed?.hide,}}
}
三、注册组件
import { createApp } from 'vue'
import App from './App.vue'
import loading from './components/loading'const app = createApp(App)type Lod = {show():void,hide():void
}declare module 'vue' {export interface ComponentCustomProperties {$Loading: Lod}
}app.use(loading)
app.mount('#app')

使用

<template><div class=""></div>
</template>
<script setup lang="ts">
import { getCurrentInstance } from 'vue';
const app = getCurrentInstance();
app?.proxy?.$Loading.show();
setTimeout(() => {app?.proxy?.$Loading.hide();
}, 2000)
</script>
<style scoped></style>

相关文章:

Vue3封装全局插件

定义一个全局加载组件 一、首先定义dom元素 定义一个index.vue文件 <template><div class"loading">loading...</div> </template> <script setup lang"ts"></script> <style scoped> .loading {display: fl…...

【Python 训练营】N_6 求素数

题目 判断101-200之间有多少个素数&#xff0c;并输出所有素数。 分析 判断素数的方法&#xff1a;用一个数分别去除2到sqrt(这个数)&#xff0c;如果能被整除&#xff0c;则表明此数不是素数&#xff0c;反之是素数。 答案 h 0 leap 1 from math import sqrt from sys …...

【图论】关键路径求法c++

代码结构如下图&#xff1a; 其中topologicalSort(float**, int, int*, bool*, int, int)用来递归求解拓扑排序&#xff0c;topologicalSort(float**, int*&, int, int, int)传参图的邻接矩阵mat与结点个数n&#xff0c;与一个引用变量数组topo&#xff0c;返回一个布尔值…...

基于51单片机电子钟万年历LCD1602显示

51单片机的电子钟万年历LCD1602显示 &#x1f534; &#x1f535;51单片机的电子钟万年历LCD1602显示&#x1f534; &#x1f535;主要功能&#xff1a;&#x1f534; &#x1f535;讲解视频&#x1f534; &#x1f535;仿真图&#xff1a;&#x1f534; &#x1f535;程序&…...

时间复杂度和运算

时间复杂度 在算法和数据结构中&#xff0c;有许多时间复杂度比 O(1) 更差的情况。以下是一些常见的时间复杂度&#xff0c;按照从最优到最差的顺序排列&#xff1a; O(1)&#xff1a; 常数时间复杂度&#xff0c;操作的运行时间与输入规模无关&#xff0c;是最理想的情况。 O…...

深入Tailwind CSS中的文本样式

深入Tailwind CSS中的文本样式 样式文本是网页设计的一个基本组成部分&#xff0c;而 Tailwind CSS 提供了范围广泛的实用类&#xff0c;使文本样式设计既高效又有效。 在本本中&#xff0c;我们将探索文本样式的常见最佳实践,讨论潜在的陷阱&#xff0c;并推荐设计方法。我们…...

系统优化软件Bitsum Process Lasso Pro v12.4,供大家学习研究参考

1、自动或手动调整进程优先级;将不需要抑制的进程添加到排除列表; 2、设置动态提升前台运行的进程/线程的优先级 3、设置进程黑名单,禁止无用进程(机制为启动即结束,而非拦截其启动)。 4、优化I/O优先级以及电源模式自动化。 5、ProBalance功能。翻译成中文是“进程平衡…...

敏捷DevOps专家王立杰:端到端DevOps持续交付的5P法则 | IDCF

今天有一个流行的英文缩写词用来刻画这个风云变幻的时代&#xff1a;VUCA&#xff08;乌卡时代&#xff09;。四个英文字母分别表示动荡性&#xff08;Volatility&#xff09;、不确定性&#xff08;Uncertainty&#xff09;、复杂性&#xff08;Complexity&#xff09;和模糊性…...

分布式锁详解

文章目录 分布式锁1. [传统锁回顾](https://blog.csdn.net/qq_45525848/article/details/134608044?csdn_share_tail%7B%22type%22:%22blog%22,%22rType%22:%22article%22,%22rId%22:%22134608044%22,%22source%22:%22qq_45525848%22%7D)1.1. 从减库存聊起1.2. 环境准备1.3. 简…...

Python入门学习篇(二)——算术运算符

1 算术运算符 1.1 分类 类型含义示例注意事项加号12➡3“12”“3"➡"123”数值之间,是加法运算(True为1,False为0)字符串之间,是进行拼接数值和字符串之间是不可以使用加法运算的,会报错-减号1-2➡-1*乘号2*3➡6/除法2/1➡2.0除法的结果永远为小数%取余10%2➡0//取…...

微软发布最新.NET 8长期支持版本,云计算、AI应用支持再强化

11 月 15 日开始的为期三天的 .NET Conf 在线活动的开幕日上&#xff0c;.NET 8作为微软的开源跨平台开发平台正式发布。.NET 团队着重强调云、性能、全栈 Blazor、AI 和 .NET MAUI 是.NET 8的主要亮点。.NET团队在 .NET Conf 2023 [1]活动开幕式上表示&#xff1a;“通过这个版…...

达索系统3DEXPERIENCE WORKS 2024 Fabrication新功能

当发现产品的制造环节&#xff0c;以及因产品模型本身的设计而导致制造环节存在不合理性&#xff0c;从而导致加工制造成本增加。 快速判断&#xff0c;轻松协作 在达索系统3DEXPERIENCE WORKS 2024中我们可以快速的判断产品的可制造性&#xff0c;以及快速与前端设计沟通协作…...

Web3与Web3.0: Web3指的是去中心化和基于区块链的网络,Web3.0指的是链接或语义网络。

目录 Web3与Web3.0: Web3指的是去中心化和基于区块链的网络 Web3.0指的是链接或语义网络。...

98、Text2Room: Extracting Textured 3D Meshes from 2D Text-to-Image Models

简介 github 利用预训练的2D文本到图像模型来合成来自不同姿势的一系列图像。为了将这些输出提升为一致的3D场景表示&#xff0c;将单目深度估计与文本条件下的绘画模型结合起来&#xff0c;提出了一个连续的对齐策略&#xff0c;迭代地融合场景帧与现有的几何形状&#xff0…...

MySQL 优化器 Index Condition Pushdown下推(ICP)

ICP 测试 准备数据 CREATE TABLE icp (employee_id int(6) NOT NULL AUTO_INCREMENT,first_name varchar(20) DEFAULT NULL,last_name varchar(25) DEFAULT NULL,email varchar(25) DEFAULT NULL,phone_number varchar(20) DEFAULT NULL,PRIMARY KEY (employee_id) );insert i…...

ruoyi 若依框架采用第三方登录

在项目中&#xff0c;前后端分离的若依项目&#xff0c;需要通过统一认证&#xff0c;或者是第三方协带认证信息跳转到本系统的指定页面。需要前后端都做相应的改造&#xff0c;由于第一次实现时已过了很久&#xff0c;再次重写时&#xff0c;发现还是搞了很长时间&#xff0c;…...

dom api

dom的全称为Document Object Model,即文档对象模型.所谓文档就是html页面,对象就是js里的对象,通过这个模型把页面上的元素和js里的对象关联起来. 下面是关于dom api的一些常用方法 1.获取元素 使用querySelector()方法获取一个元素 使用querySelectorAll()方法获取所有元素 当…...

音视频项目—基于FFmpeg和SDL的音视频播放器解析(二十一)

介绍 在本系列&#xff0c;我打算花大篇幅讲解我的 gitee 项目音视频播放器&#xff0c;在这个项目&#xff0c;您可以学到音视频解封装&#xff0c;解码&#xff0c;SDL渲染相关的知识。您对源代码感兴趣的话&#xff0c;请查看基于FFmpeg和SDL的音视频播放器 如果您不理解本…...

Qt项目打包发布超详细教程

https://blog.csdn.net/qq_45491628/article/details/129091320...

简单递归题

本来不想用递归做的&#xff0c;最后还是用了 题目如下&#xff1a; 洪尼玛有 n 块长度不同的木板&#xff0c;他想用这些木板拼成一个等边三角形的围栏&#xff0c;好将他的草泥马养在这个围栏里面。现在&#xff0c;给你这 n 块木板的长度&#xff0c;洪尼玛想知道他能否拼…...

以学代练:用竞赛真题学算法——二叉树

先上题目&#xff0c;出自蓝桥杯省赛真题题目描述给定一棵包含 N 个节点 的完全二叉树&#xff0c;树上每个节点都有权值。节点按照从上到下、从左到右的顺序依次编号为 A1​,A2​,…,AN​。现在需要把同一深度&#xff08;同一层&#xff09;的所有节点权值相加&#xff0c;求…...

AI大语言模型狂飙突进的技术巅峰与商业风暴

&#x1f4cc; 前言 | AI 时代的大语言模型到底有多“大”&#xff1f; 自从 2018 年 GPT 系列问世之后&#xff0c;大语言模型&#xff08;LLM&#xff09;便成为人工智能领域最耀眼的明星。它们不再仅仅用来“对话”&#xff0c;更开始在科研、医疗、制造业乃至法律与金融等领…...

2026年最新排班管理软件盘点!10款主流排班管理软件功能对比与选型指南

在2026年的企业数字化管理版图中&#xff0c;排班管理软件已经不再是可有可无的辅助工具&#xff0c;而是决定企业人效与合规性的核心武器。面对日益复杂的用工环境&#xff0c;无论是连锁零售的碎片化排班&#xff0c;还是高端制造的复杂倒班&#xff0c;一款高效的排班管理软…...

Verilog状态机实战:手把手教你设计一个可复用的序列检测器(附完整Testbench)

Verilog状态机实战&#xff1a;构建可配置序列检测器的工程化方法 在数字IC设计中&#xff0c;序列检测器是验证工程师和设计者经常遇到的基础电路模块。传统教程往往聚焦于特定序列&#xff08;如1001&#xff09;的检测实现&#xff0c;却很少探讨如何将这类设计转化为可复用…...

避坑指南:在Proteus8中仿真51单片机红外通信(IRLINK)时,如何解决载波频率和协议解析的那些坑?

Proteus8仿真51单片机红外通信的五大核心陷阱与精准解决方案 当你在深夜调试Proteus8中的51单片机红外通信项目时&#xff0c;示波器上那些杂乱无章的波形是否曾让你陷入绝望&#xff1f;IRLINK模块看似简单&#xff0c;却暗藏诸多玄机。本文将从五个关键维度&#xff0c;解剖那…...

告别手动拖拽!用Lumerical脚本批量搭建FDTD仿真结构(附完整代码)

告别手动拖拽&#xff01;用Lumerical脚本批量搭建FDTD仿真结构&#xff08;附完整代码&#xff09; 在光子学仿真领域&#xff0c;时间就是创新的货币。当你在凌晨三点反复调整第37个纳米柱的旋转角度时&#xff0c;是否想过&#xff1a;那些本应用于突破性思考的精力&#xf…...

别再傻傻分不清了!一文搞懂UART、RS232、RS485和RS-422到底怎么选(附选型指南)

串口通信协议终极选型指南&#xff1a;UART、RS232、RS485与RS-422深度解析 在工业自动化、物联网设备开发或嵌入式系统设计中&#xff0c;工程师们经常面临一个基础却关键的选择&#xff1a;如何为设备间的数据通信选择合适的串口协议&#xff1f;UART、RS232、RS485和RS-422这…...

Avalonia v11跨平台实战:从安装到多平台项目部署

1. Avalonia v11初体验&#xff1a;为什么选择这个跨平台UI框架&#xff1f; 第一次接触Avalonia是在去年一个需要同时支持Windows和macOS的项目中。当时尝试过几种跨平台方案&#xff0c;要么性能堪忧&#xff0c;要么开发体验差强人意。直到同事推荐了Avalonia&#xff0c;用…...

【源码深度】Android 架构设计+组件化+模块化+插件化|面试终章 第29讲

...

终极指南:如何用STB字符串哈希表避开90%的C语言坑

终极指南&#xff1a;如何用STB字符串哈希表避开90%的C语言坑 【免费下载链接】stb stb single-file public domain libraries for C/C 项目地址: https://gitcode.com/GitHub_Trending/st/stb 在C语言开发中&#xff0c;手动管理数据结构往往是错误的重灾区。内存泄漏、…...