【Vue3】局部组件和全局组件

1. 局部组件

Card.vue

js 复制代码
<template>
  <div class="card">
    <header>
      <div>标题</div>
      <div>副标题</div>
    </header>
    <section>内容</section>
  </div>
</template>

<script setup lang="ts">

</script>

<style lang="less" scoped>
@border: #ccc;
.card {
  border: 1px solid @border;
  width: 400px;
  header {
    display: flex;
    justify-content: space-between;
    padding: 5px;
    border-bottom: 1px solid @border;
  }
  section{
    padding: 5px;
    min-height: 300px;
  }
}
</style>

App.vue

js 复制代码
<template>
  <div>
    <CardVue></CardVue>
  </div>
</template>

<script setup lang="ts">
import CardVue from './components/Card.vue'

</script>

<style lang="scss" scoped>

</style>

2. 全局组件

2.1 注册单个全局组件

Cardvue

js 复制代码
// 同上

App.vue

js 复制代码
<template>
  <div>
    <Card></Card>
  </div>
</template>

<script setup lang="ts">
</script>

<style lang="scss" scoped></style>

main.ts

js 复制代码
import { createApp } from 'vue'
import App from './App.vue'
import CardVue from './components/Card.vue'
export const app = createApp(App)
app.component('Card', CardVue)
app.mount('#app')

2.2 批量注册全局组件

Card.vue

js 复制代码
// 同上

Tree.vue

js 复制代码
<template>
  <div>
      <h1>this is a title</h1>
  </div>
</template>

<script setup lang="ts">
</script>

<style lang="scss" scoped>
h1 {
  border: 1px solid black;
}
</style>

App.vue

js 复制代码
<template>
  <div>
    <Card></Card>
    <Tree></Tree>
  </div>
</template>

<script setup lang="ts">
</script>

<style lang="scss" scoped></style>

main.ts

js 复制代码
import { createApp, defineAsyncComponent } from 'vue'
import App from './App.vue'
const app = createApp(App)
const componentNames = ['Card', 'Tree'];
// 使用动态导入的方式注册全局组件时需要注意异步组件的加载
// 异步组件使用 defineAsyncComponent 方法来处理动态导入的组件,并且使用 await 关键字等待组件的加载完成。在组件加载完成后,再将其注册为全局组件。
// 如果没有注意异步组件的加载,会报 Invalid VNode type: undefined (undefined) 的问题
async function registerComponents() {
  for (const componentName of componentNames) {
    // 使用 defineAsyncComponent 方法动态导入异步组件
    const component = await defineAsyncComponent(() => import(`./components/${componentName}.vue`));
    app.component(componentName, component);
  }
  app.mount('#app');
}
registerComponents();
相关推荐
用户831348593069812 分钟前
Cesium实现雾气效果:按钮一键控制打开/关闭雾气效果,滑块拖动实时控制雾气浓度
vue.js·cesium
壹方秘境28 分钟前
ApiCatcher支持抓包HTTP传输大文件的实现原理分享
前端·后端·客户端
一份执念40 分钟前
uni-app项目 (vue+vite + uni-UI)中引入umd格式JS文件,微信小程序中导入报错处理方案
前端·uni-app·echarts
To_OC43 分钟前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
ClouGence1 小时前
2026 年自动化测试工具选型指南:8 款主流工具对比
前端·测试
lichenyang4531 小时前
为什么需要双线程通信、JavaScriptProxy 和 runJavaScript 分别干什么
前端
以和为贵2 小时前
前端也能搞懂 RAG:用 JS 手写一条最小检索增强链路
前端·人工智能·面试
风止何安啊2 小时前
网课倍速痛点解决:一套前端代码实现自由控速播放器
前端·javascript·node.js
牧艺2 小时前
用 Next.js + React Three Fiber 打造 3D 快递仓储可视化
前端·three.js
锋行天下3 小时前
如何用Vite实现Vue组件的按需打包和远程加载
前端·vue.js·前端框架