Vue 3 第二十章:组件八(组件高级特性-组件的全局注册和局部注册)

news2024/10/5 14:12:47

文章目录

  • 1. 全局注册组件
  • 2. 局部注册组件

Vue3 允许我们在全局注册组件,这使得我们可以构建更加灵活和可扩展的应用程序。同时,局部注册可以帮助我们更好地组织代码并提高应用程序的性能。

1. 全局注册组件

通过 app.component 方法可以在 Vue3 中创建一个全局组件:
在这里插入图片描述

import { createApp } from "vue";
import App from "./App.vue";

// 自己封装的组件
import Button from "./components/Button/index.vue";

// 链式调用,component参数一:组件name,参数二:组件实例
// 注意:此处component一定要在mount之前
createApp(App).component("btn", Button).mount("#app");

在上面的代码中,我们先定义了一个名为 btn 的组件,然后使用 app.component 方法将其注册为全局组件。这样,在应用程序的任何地方都可以使用 <btn> 元素来加载该组件。

2. 局部注册组件

全局注册虽然很方便,但有以下几个问题:

  • 全局注册,但并没有被使用的组件无法在生产打包时被自动移除 (也叫“tree-shaking”)。如果你全局注册了一个组件,即使它并没有被实际使用,它仍然会出现在打包后的JS文件中。

  • 全局注册在大型项目中使项目的依赖关系变得不那么明确。在父组件中使用子组件时,不太容易定位子组件的实现。和使用过多的全局变量一样,这可能会影响应用长期的可维护性

相比之下,局部注册的组件需要在使用它的父组件中显式导入,并且只能在该父组件中使用。它的优点是使组件之间的依赖关系更加明确,并且对tree-shaking更加友好。

在使用<script setup>的单文件组件中,导入的组件可以直接在模板中使用,无需注册:

<template>
  <div>
    <local-component></local-component>
  </div>
</template>

<script setup laang="ts">
import LocalComponent from "./LocalComponent.vue";

</script>

如果没有使用 <script setup>,则需要使用components选项来显式注册:

<template>
  <div>
    <local-component></local-component>
  </div>
</template>

<script>
import LocalComponent from "./LocalComponent.vue";

export default {
	components: { LocalComponent },
	setup() {
		// ...
	}
}
</script>

在上面的代码中,我们在组件中注册了一个名为 LocalComponent 的组件,并将其包含在组件模板中。由于该组件只能在该组件内部使用,因此我们只需要在该组件内部进行注册即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/540141.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

钓鱼对抗之 Coremail安全拦截

作者简介&#xff1a; 胡晓磊&#xff0c;男&#xff0c;山东省城市商业银行合作联盟有限公司邮箱管理员&#xff0c;Coremail管理员社区特邀大咖 钓鱼邮件&#xff0c;是一种常见的网络诈骗手段。一般目的是用来欺骗收件人&#xff0c;将账号、口令或密码等信息回复给指定的接…

(数字图像处理MATLAB+Python)第八章图像复原-第五、六节:盲去卷积复原和几何失真校正

文章目录 一&#xff1a;盲去卷积复原&#xff08;1&#xff09;概述&#xff08;2&#xff09;程序 二&#xff1a;几何失真校正&#xff08;1&#xff09;概述&#xff08;2&#xff09;程序 一&#xff1a;盲去卷积复原 &#xff08;1&#xff09;概述 盲去卷积复原&#…

Java中的ORM框架有哪些,Hibernate 使用讲解

简介 在Java开发中&#xff0c;使用ORM框架是一种常见的开发方式。ORM&#xff08;Object-Relational Mapping&#xff09;框架是一种将对象模型和关系模型进行映射的技术&#xff0c;它使得Java开发人员可以使用面向对象的方式来操作关系型数据库&#xff0c;而无需直接使用S…

拍卖行搜索包分析

《天涯明月刀》的明文包内容大多比较简单&#xff0c;不过也有个别封包的结构较大&#xff0c;分析起来较为复杂&#xff0c;以拍卖行的搜索函数为例。 首先通过send返回到明文包的位置(如图) 这个封包的大小为0x56&#xff0c;随意搜索一个物品的名字使游戏断下(如图) 在这…

Vue 3 脚手架搭建

Vue 3 脚手架搭建 一、环境准备1.1 node.js 安装1.2 包管理工具安装&#xff1a;可选 二、创建项目2.1 使用 npm2.2 使用 yarn 三、配置项目3.1 安装初始依赖3.2 增加依赖3.2 配置自动导包3.3 配置 eslint 规则3.4 .vue 文件导入报错解决 四、路由配置4.1 路由类型定义4.2 inde…

加密解密软件VMProtect入门使用教程(八)控制台版本

VMProtect是新一代软件保护实用程序。VMProtect支持德尔菲、Borland C Builder、Visual C/C、Visual Basic&#xff08;本机&#xff09;、Virtual Pascal和XCode编译器。 同时&#xff0c;VMProtect有一个内置的反汇编程序&#xff0c;可以与Windows和Mac OS X可执行文件一起…

【C++初阶】模板

⭐博客主页&#xff1a;️CS semi主页 ⭐欢迎关注&#xff1a;点赞收藏留言 ⭐系列专栏&#xff1a;C初阶 ⭐代码仓库&#xff1a;C初阶 家人们更新不易&#xff0c;你们的点赞和关注对我而言十分重要&#xff0c;友友们麻烦多多点赞&#xff0b;关注&#xff0c;你们的支持是我…

Java应用程序性能调优的秘诀:掌握JVM自带的命令行工具

Java 自带了多个 JVM 调优工具&#xff0c;以下是其中一些常用的工具&#xff1a; 1&#xff09;jps&#xff08;JVM Process Status Tool&#xff09;&#xff1a; 用于显示当前系统中所有正在运行的 Java 进程的 PID 和相关信息。 2&#xff09;jstat&#xff08;JVM Stati…

常用的表格检测识别方法-表格区域检测方法(上)

常用的表格检测识别方法 表格检测识别一般分为三个子任务&#xff1a;表格区域检测、表格结构识别和表格内容识别。本章将围绕这三个表格识别子任务&#xff0c;从传统方法、深度学习方法等方面&#xff0c;综述该领域国内国外的发展历史和最新进展&#xff0c;并提供几个先进…

ERP、SCM与CRM系统的关系和区别是什么?

在当今数字化时代&#xff0c;企业管理系统扮演着至关重要的角色&#xff0c;而ERP、SCM和CRM系统是其中三个核心组成部分。 虽然它们都在企业管理中发挥着关键作用&#xff0c;但它们各自的功能和应用领域存在一些区别。 我们先来看看&#xff0c;ERP、SCM与CRM系统分别是啥…

张驰咨询:突破瓶颈降低成本-精益生产咨询的实践策略

在现代企业运营中&#xff0c;提高效率、优化流程是实现成功的关键因素之一。为了帮助企业在这方面取得突破性的进展&#xff0c;精益生产咨询成为了一种备受推崇的方法。本文将介绍精益生产咨询的基本原理、优势以及如何将其应用于企业实践中。 精益生产咨询是一种源于丰田生…

软考- 受限双端队列出队顺序--后面有历年真题

前提&#xff1a;栈和队列 栈&#xff1a; 先进后出 队列&#xff1a;先进先出 对于元素1&#xff0c;2&#xff0c;3&#xff0c;4按照顺序进出栈和队列时&#xff1a; 对于入栈&#xff0c;出栈时&#xff1a; 可以进一个元素&#xff0c;出一个元素&#xff1a; 能得…

基于MATLAB的车牌识别系统+GUI界面的毕业设计(完整源码+课题报告+说明文档+数据)

文章目录 1. 前言2. 实现步骤1&#xff09;颜色信息提取2&#xff09;倾斜校正3&#xff09;字符分割4&#xff09;字体识别5&#xff09;语音播报6&#xff09;存储数据 3. 效果展示4. 总结5. 完整源码下载 1. 前言 近年来,随着交通现代化的发展要求,汽车牌照自动识别技术已经…

网络安全实验——web安全

目录 实验目的 实验原理 实验内容 实验1 1. 地址栏中执行脚本 2. 对DOM技术的利用 实验2 1.jump1 2.jump2 3.get 4.xss 5.注册bss 6.盗取cookie 7.分析cookie 实验3 一.搭建IIS服务器 二.身份验证和权限设置 三.IP地址和域名限制 四.安全通信 五. 单点登录 …

《终身成长》笔记四——如何面对失败

目录 经典摘录 秉性 一个英雄具备的所有特质 ​编辑 什么是成功 什么是失败 掌控成功 领导力与固定型思维模式 成长型思维模式领导者的行为 害羞 经典摘录 秉性 天才们&#xff0c;因为自己拥有的优势而得意忘形&#xff0c;不去学习如何努力奋斗以及如何面对挫折。…

Win10系统开机使用一段时间会变成蓝屏怎么办?

Win10系统开机使用一段时间会变成蓝屏怎么办&#xff1f;最近有用户在使用电脑的时候遇到了一个问题&#xff0c;当自己开机使用了一段时间之后&#xff0c;电脑就会变成蓝屏无法操作&#xff0c;导致自己的使用中断了。如果经常出现这样的问题&#xff0c;那么就需要去进行电脑…

图解LeetCode——141. 环形链表

一、题目 给你一个链表的头节点 head &#xff0c;判断链表中是否有环。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置&a…

使用jsDelivr和GitHub,上传本地静态资源到免费CDN

目标&#xff1a;将本地图片资源上传到免费CDN&#xff0c;以便随时使用&#xff01;其他静态资源亦可&#xff0c;例如&#xff1a;js、css、pdf、word、excel 等等 ①在github上创建新仓库&#xff1a;resources&#xff0c;用于存放要上传到 CDN 的静态资源&#xff1a; ②上…

成都欢蓬信息:抖音电商去年GMV增速超80%

在今年的抖音电商生态大会上&#xff0c;抖音电商交出了年度“成绩单”。 5月16日&#xff0c;抖音电商总裁魏雯雯披露&#xff0c;近一年抖音电商GMV&#xff08;成交额&#xff09;增幅超80%。其中&#xff0c;商城GMV同比增长277%&#xff0c;电商搜索GMV同比增长159%&#…

NAVICAT 自动备份数据库到本地

1:设置备份文件存储路径地址 右键数据库连接 ——》编辑连接——》高级 2:选择要备份的数据库 点击 备份——》新建备份——》对象选择 ——》保存 输入文件名称 ——》确定 备份 下出现 保存的备份文件 3:设置自动备份 点击 自动运行——》新建批处理作业 点击 新建…