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

Vue 3 中如何注册全局自定义组件:一个 SVG 图标的例子

Vue 3 中如何注册全局自定义组件:一个 SVG 图标的例子

嘿,小伙伴们!今天我们来聊一下在 Vue 3 中如何注册一个全局的自定义组件。我知道有时候我们想要重复使用某些组件,比如说 SVG 图标,但不想在每个地方都重新定义。那么,我们该怎么做呢?🤔

什么是全局组件?

全局组件就是不管你在哪里都可以直接使用的组件,无需在子组件中一次次地引入和注册。这就好像你在厨房做饭时,把盐和胡椒粉放在一个随手可拿的地方,总比每次使用都要去储物柜找要方便多了!🍴

SVG 图标封装成组件

首先,我们要为我们的 SVG 图标创建一个简单的组件。假设我们要使用如下的 SVG:

<svg><use xlink:href="#icon-luxian" />
</svg>

我们想把它封装成一个组件 <svg-icon>,并可以传递一些参数,比如 namecolorwidthheight。下面就是我们的组件实现,在components中创建SvgIcon文件夹创建index.vue:

<template><div><svg :style="{ width: width, height: height }"><use :xlink:href="prefix + name" :fill="color"></use></svg></div>
</template><script setup lang="ts">
defineProps({prefix: {type: String,default: '#icon-'},name: String,color: {type: String,default: ""},width: {type: String,default: '100px'},height: {type: String,default: '100px'}
})
</script><style scoped></style>

这里我们使用 defineProps 来接受父组件传递的参数,比如 namecolor。是不是很简单?😄

批量注册全局组件

接下来,我们要想办法批量注册这些全局组件。为此,我们在 components 目录下创建一个 index.ts 文件,负责注册所有的全局组件:

import SvgIcon from './SvgIcon/index.vue';
import type { App, Component } from 'vue';const components: { [name: string]: Component } = { SvgIcon };export default {install(app: App) {Object.keys(components).forEach((key: string) => {app.component(key, components[key]);});}
}

这段代码创建了一个可以被 Vue 3 应用安装的插件。通过遍历 components 对象,我们能够把所有组件都注册为全局组件。

在入口文件中使用

最后,只需在你的 main.ts 文件中使用我们创建的插件:

import { createApp } from 'vue';
import App from './App.vue';
import globalComponent from '@/components';const app = createApp(App);app.use(globalComponent); // 自动执行 install 方法app.mount('#app');

好了,这样我们就能在应用中的任何地方使用我们的 <svg-icon> 组件了,是不是超酷的😁?

结论

当你有一些通用的组件需要在多个页面中使用时,注册为全局组件无疑是一个非常不错的选择。这样不仅能让代码更加简洁,还能避免重复定义和使用可能导致的错误。

相关文章:

Vue 3 中如何注册全局自定义组件:一个 SVG 图标的例子

Vue 3 中如何注册全局自定义组件&#xff1a;一个 SVG 图标的例子 嘿&#xff0c;小伙伴们&#xff01;今天我们来聊一下在 Vue 3 中如何注册一个全局的自定义组件。我知道有时候我们想要重复使用某些组件&#xff0c;比如说 SVG 图标&#xff0c;但不想在每个地方都重新定义。…...

SpringBoot+Vue3-学习笔记

1、SpringBoot特性 ①起步依赖&#xff0c;所有需要的依赖全部配置在一起 ②自动配置&#xff1a;遵循约定大约配置的原则&#xff0c;在boot程序启动后&#xff0c;一些bean对象会自动注入到ioc容器&#xff0c;不需要手动声明&#xff0c;简化开发 ③内嵌的Tomcat、Jetty(无…...

银河麒麟系统安装mysql5.7【亲测可行】

一、安装环境 cpu&#xff1a;I5-10代&#xff1b; 主板&#xff1a;华硕&#xff1b; OS&#xff1a;银河麒麟V10&#xff08;SP1&#xff09;未激活 架构&#xff1a;Linux 5.10.0-9-generic x86_64 GNU/Linux mysql版本&#xff1a;mysql-5.7.34-linux-glibc2.12-x86_64.ta…...

为什么WP建站更适合于谷歌SEO优化?

在当今数字时代&#xff0c;建立一个网站似乎变得容易&#xff0c;但要构建一个真正能够带来流量和订单的网站却并非易事。特别是在谷歌SEO优化方面&#xff0c;不同的建站程序在SEO支持方面的效果差异显著。对于希望提升搜索引擎表现的用户来说&#xff0c;WordPress无疑是最佳…...

ue----git局域网内部署裸仓库,别的机器进行访问

最近由于经常迁移项目到另一台机器上进行部署更新一点就要整个迁移 弄得麻烦了 就在网上学了一下这个方式 首先我们在想要建立裸仓库的电脑上找到一个文件夹放置我们的裸仓库 在此点击鼠标右键选择 open git bash here 输入命令 创裸仓库 git init --bare gitTestName.git…...

leetcode876.链表的中间结点

目录 问题描述示例提示 具体思路思路一 代码实现 问题描述 给你单链表的头结点 head &#xff0c;请你找出并返回链表的中间结点。 如果有两个中间结点&#xff0c;则返回第二个中间结点。 题目链接&#xff1a;链表的中间结点 示例 提示 链表的结点数范围是 [1, 100]   1 &…...

旧手机热点无法提供ipv6解决方法(emui 8 热点提供ipv6)

旧手机热点无法提供ipv6解决方法 手机&#xff1a;荣耀8x 系统版本: EMUI 8 网络&#xff1a;移动流量卡 解决方案 设置-》无线和网络-》移动网络-》接入点名称(APN)-》cmiot 修改 APN协议: IPv4/IPv6 修改 APN漫游协议: IPv4/IPv6...

解决DeepSeek服务器繁忙问题的实用指南

目录 简述 1. 关于服务器繁忙 1.1 服务器负载与资源限制 1.2 会话管理与连接机制 1.3 客户端配置与网络问题 2. 关于DeepSeek服务的备用选项 2.1 纳米AI搜索 2.2 硅基流动 2.3 秘塔AI搜索 2.4 字节跳动火山引擎 2.5 百度云千帆 2.6 英伟达NIM 2.7 Groq 2.8 Firew…...

新数据结构(12)——代理

什么是代理 在进行操作时有时不希望用户直接接触到目标&#xff0c;这时需要使用代理让用户间接接触到目标 给目标对象提供一个代理对象&#xff0c;并且由代理对象控制着对目标对象的引用 图解&#xff1a; 代理的目的 控制访问&#xff1a;通过代理对象的方式间接的访问目…...

记一次一波三折的众测SRC经历

视频教程和更多福利在我主页简介或专栏里 &#xff08;不懂都可以来问我 专栏找我哦&#xff09; 目录&#xff1a; 前言 波折一&#xff1a;RCE漏洞利用失败 波折二&#xff1a;SQL时间盲注 波折三&#xff1a;寻找管理后台 总结 前言 先谈个人SRC心得体会吧&#xff0c;我虽…...

Laravel从入门到上云

大家好&#xff0c;今天给大家介绍一下PHP的经典框架Laravel。 本文假定你已经安装好了PHP执行环境&#xff0c;并且使用PHP版本为PHP8.0以上。 首先&#xff0c;让我们来安装Laravel框架&#xff0c;执行命令&#xff1a;composer create-project laravel/laravel 命令执行…...

【小游戏】C++控制台版本俄罗斯轮盘赌

制作团队&#xff1a;洛谷813622&#xff08;Igallta&#xff09; 989571&#xff08;_ayaka_&#xff09; Mod&#xff1a;_ayaka_ 双人模式&#xff1a;Igallta 公告&#xff1a; 原先的9.8改名为 Alpha 1.0&#xff0c;以后每次更新都增加 0.1。 Alpha 1.11 改为 Beta 1…...

【前端】使用WebStorm创建第一个项目

文章目录 前言一、步骤1、启动2、创建项目3、配置Node.js4、运行项目 二、Node.js介绍 前言 根据前面文章中记录的步骤&#xff0c;已经安装好了WebStorm开发软件&#xff0c;接下来我们就用这个IDE开发软件创建第一个项目。 一、步骤 1、启动 启动软件。 2、创建项目 新建…...

前后端项目部署服务器(传统部署和Docker部署)

内外网 开发环境连外网&#xff08;8.140.26.187&#xff09;&#xff0c;测试/生产环境连内网&#xff08;172.20.59.17&#xff09; 内外网地址不同&#xff0c;但指定的库是同一个 内网IP地址范围包括&#xff1a; 10.0.0.0 到 10.255.255.255172.16.0.0 到 172.31.2551…...

C++,设计模式,【工厂方法模式】

文章目录 如何用汽车生产线理解工厂方法模式?一、传统生产方式的困境二、工厂方法模式解决方案三、模式应用场景四、模式优势分析五、现实应用启示✅C++,设计模式,【目录篇】 如何用汽车生产线理解工厂方法模式? 某个早晨,某车企CEO看着会议室里堆积如面的新车订单皱起眉…...

golang--字符串处理(rune类型)

在 Go 语言中&#xff0c;rune 类型是一个非常重要的基础类型&#xff0c;用于处理 Unicode 字符。以下是关于 rune 类型的详细用法说明&#xff1a; 一、基础概念 类型定义 rune 是 int32 的别名&#xff08;type rune int32&#xff09;&#xff0c;表示一个 Unicode 码点&a…...

如何通过AI优化敏捷开发中的任务管理与分配?

用ChatGPT做软件测试 在现代软件开发中&#xff0c;敏捷开发&#xff08;Agile&#xff09;已成为一种广泛采用的开发方法论&#xff0c;其核心思想是强调快速响应变化、与客户的持续沟通以及团队协作的高效性。然而&#xff0c;随着项目规模的不断扩大&#xff0c;敏捷开发面临…...

第1章大型互联网公司的基础架构——1.11 消息中间件技术

消息队列&#xff08;Message Queue&#xff09;是分布式系统中最重要的中间件之一&#xff0c;在服务架构设计中被广泛使用。 1.11.1 通信模式与用途 消息中间件构建了这样的通信模式&#xff1a; 一条消息由生产者创建&#xff0c;并被投递到存放消息的队列中&#xff1b;…...

FlutterAssetsGenerator插件的使用

在Plugins中找到FlutterAssetsGenerator插件&#xff0c;点击安装。 更改生成的资源索引类可以修改名字。 在根目录下创建assets/images文件夹&#xff0c;用于存储图片。 点击images文件夹&#xff0c;鼠标右键点击Flutter&#xff1a;Configuring Paths&#xff0c;pub…...

EasyExcel 自定义头信息导出

需求&#xff1a;需要在导出 excel时&#xff0c;合并单元格自定义头信息(动态生成)&#xff0c;然后才是字段列表头即导出数据。 EasyExcel - 使用table去写入&#xff1a;https://easyexcel.opensource.alibaba.com/docs/current/quickstart/write#%E4%BD%BF%E7%94%A8table%E…...

技术视角:Bulk Crap Uninstaller的架构解析与批量卸载实现原理

技术视角&#xff1a;Bulk Crap Uninstaller的架构解析与批量卸载实现原理 【免费下载链接】Bulk-Crap-Uninstaller Remove large amounts of unwanted applications quickly. 项目地址: https://gitcode.com/gh_mirrors/bu/Bulk-Crap-Uninstaller 在Windows系统管理的技…...

告别复杂手打:3个技巧让你用GSE轻松实现魔兽世界智能一键输出

告别复杂手打&#xff1a;3个技巧让你用GSE轻松实现魔兽世界智能一键输出 【免费下载链接】GSE-Advanced-Macro-Compiler GSE is an alternative advanced macro editor and engine for World of Warcraft. 项目地址: https://gitcode.com/gh_mirrors/gs/GSE-Advanced-Macro…...

终极抢票神器:大麦助手DamaiHelper完整使用指南

终极抢票神器&#xff1a;大麦助手DamaiHelper完整使用指南 【免费下载链接】damaihelper 支持大麦网&#xff0c;淘票票、缤玩岛等多个平台&#xff0c;演唱会演出抢票脚本 项目地址: https://gitcode.com/gh_mirrors/dam/damaihelper 还在为抢不到演唱会门票而烦恼吗&…...

Spring Boot 2.3.12 + Spring Batch 实战:用注解搞定学生成绩单批量计算(附完整源码)

Spring Boot 2.3.12 Spring Batch 实战&#xff1a;用注解搞定学生成绩单批量计算&#xff08;附完整源码&#xff09; 在当今教育信息化快速发展的背景下&#xff0c;学校教务系统每天都需要处理大量的学生成绩数据。传统的手工录入和计算方式不仅效率低下&#xff0c;而且容…...

Audiveris:5步将纸质乐谱转换为可编辑数字乐谱的完整指南

Audiveris&#xff1a;5步将纸质乐谱转换为可编辑数字乐谱的完整指南 【免费下载链接】audiveris Latest generation of Audiveris OMR engine 项目地址: https://gitcode.com/gh_mirrors/au/audiveris 你是否曾面对堆积如山的纸质乐谱感到无从下手&#xff1f;那些珍贵…...

G1垃圾收集器四大关键机制原理详细描述

目录 G1垃圾收集器四大关键机制原理详细描述 一、Region分区化(核心基础机制) 1. 核心设计原理 2. 关键角色划分及作用 3. 核心作用 二、记忆集(Remembered Set,RSet) 1. 核心设计背景 2. 原理详细描述 3. 工作流程(结合GC场景) 4. 核心作用 三、卡表(CardT…...

Krita AI Diffusion:数字创作工作流中的AI集成解决方案

Krita AI Diffusion&#xff1a;数字创作工作流中的AI集成解决方案 【免费下载链接】krita-ai-diffusion Streamlined interface for generating images with AI in Krita. Inpaint and outpaint with optional text prompt, no tweaking required. 项目地址: https://gitcod…...

别再乱用Python List了!PyTorch中ModuleList和ModuleDict的正确打开方式(附避坑指南)

PyTorch模型设计进阶&#xff1a;为什么你的网络层参数会神秘消失&#xff1f; 在PyTorch模型开发中&#xff0c;许多开发者都曾遇到过这样的灵异事件&#xff1a;明明定义了网络层&#xff0c;训练时却提示"参数未注册"&#xff1b;将模型转移到GPU时&#xff0c;部…...

AWS开源多智能体协作框架agent-squad:构建AI特工小队实现复杂任务自动化

1. 项目概述&#xff1a;当AI智能体组成“特工小队”如果你最近在关注AI应用开发的前沿动态&#xff0c;那么“智能体”&#xff08;Agent&#xff09;这个词一定不会陌生。它不再是科幻电影里的概念&#xff0c;而是指那些能够理解目标、使用工具、并自主执行复杂任务的AI程序…...

LinkSwift:八大网盘直链下载助手终极指南 - 免费获取高速下载链接的完整教程

LinkSwift&#xff1a;八大网盘直链下载助手终极指南 - 免费获取高速下载链接的完整教程 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 &#xff0c;支持 百度网盘 / 阿里云盘 …...