Vue 全局组件与局部组件

全局组件(global components) 是能在整个Vue app的任意模板内使用的组件,在main.js 内调用 component() 方法注册的组件都是全局组件:

import { createApp } from 'vue';
import App from './App.vue';
import BaseBadge from './components/BaseBadge.vue';

const app = createApp(App);

// 注册全局组件,base-badge 能在整个Vue app的任意模板内使用
app.component('base-badge', BaseBadge);

app.mount('#app');

一般而言,组件越多,代码包也就越多,如果这些组件全部注册为全局组件,那么 Vue 需要在加载应用程序时加载全部的组件,浏览器因此一开始就需要下载所有这些组件的代码。 对于大型应用程序,可能会对performance造成影响。

除了可以调用 component() 方法将组件注册为全局组件,也可以在组件内部将计划要使用的组件本地注册为局部组件(local compoents)

// App.vue
<template>
  <div>
  	<!-- 使用kebab-case 需要加 self-closing tag, PascalCase 不需要 -->
    <!-- <the-header></the-header> -->
    <TheHeader />
    <badge-list></badge-list>
    <user-info
      :full-name="activeUser.name"
      :info-text="activeUser.description"
      :role="activeUser.role"
    ></user-info>
  </div>
</template>

<script>
import TheHeader from './components/TheHeader.vue';
import BadgeList from './components/BadgeList.vue';
import UserInfo from './components/UserInfo.vue';

export default {
  // 注册局部组件
  components: {
    //写成'the-header':TheHeader  也可以
    TheHeader,
    
    // Vue 会自动将 PascalCase 翻译成 kebab-case
    BadgeList,
    UserInfo,
  },
  data() {
    return {
      activeUser: {
        name: 'Maximilian Schwarzmüller',
        description: 'Site owner and admin',
        role: 'admin',
      },
    };
  },
};
</script>

和全局组件不同,局部注册的组件只能在该组件内部使用,不能在任何其他子组件中使用,不能在Vue app的任何其他地方使用。
以上述 App.vue 为例,3 个局部注册的组件 TheHeaderBadgeListUserInfo 只能在这个文件 App.vue 内部使用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue项目中可以使用全局组件局部组件全局组件是在入口函数main.js中声明的组件。通过在main.js中注册全局组件,可以在任意子组件中直接使用该全局组件,而无需再进行导入、声明和引用的流程。这样可以方便地在整个项目中共享和重用组件局部组件是在组件的父组件中声明的组件。在根组件App.vue中,可以直接在<template>标签中引用局部组件,无需导入和声明。这样的组件只能在父组件及其子组件中使用,不能在其他组件中直接引用。 如果想了解更详细的Vue注册全局组件局部组件的过程解析,可以参考一些相关的教程和示例代码。这些教程和示例代码会详细介绍如何注册和使用全局组件局部组件,对于学习和工作都具有一定的参考价值。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Vue----局部组件全局组件](https://blog.csdn.net/qq_40132294/article/details/124903389)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [VUE注册全局组件局部组件过程解析](https://download.csdn.net/download/weixin_38582506/12934944)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值