详解Vue3中如何使用动态组件

在 Vue 3 中,动态组件是一种允许在运行时动态切换组件的机制,本文主要为大家详细介绍了动态组件在Vue3中的具体使用。

Vue 3 提供了 元素以及 is 特性来实现动态组件的切换。

一、使用元素

在模板中使用 元素,通过 is 特性来动态切换组件:

javascript 复制代码
<template>
  <div>
    <el-tabs type="card" v-model="activeName" @tab-click="handleClick">
      <el-tab-pane label="待审核" name="1" />
      <el-tab-pane label="已通过" name="2" />
      <el-tab-pane label="未通过" name="3" />
      <el-tab-pane label="黑名单" name="4" />
    </el-tabs>
    <component
      ref="componentRef"
      :is="componentName"
      :activeName="activeName"
    ></component>
  </div>
</template>
<script setup>
import { ref, toRefs, computed, markRaw, nextTick } from "vue";
// 待提交
import PendingReview from "./pendingReview.vue";
// 已通过
import Passed from "./passed.vue";
// 未通过
import NotPass from "./notPass.vue";
// 黑名单
import Blacklist from "./blacklist.vue";

const componentRef = ref();


const activeName = ref("1");
const componentName = ref(markRaw(PendingReview));

const handleClick = (tab) => {
  if (tab.paneName === "1") {
    componentName.value = markRaw(PendingReview);
  } else if (tab.paneName === "2") {
    componentName.value = markRaw(Passed);
  } else if (tab.paneName === "3") {
    componentName.value = markRaw(NotPass);
  } else {
    componentName.value = markRaw(Blacklist);
  }
};
</script>
<style></style>

二、使用 v-if 或 v-show

除了 元素,你也可以使用 v-if 或 v-show 来动态渲染组件:

javascript 复制代码
<template>
  <div>
    <el-tabs type="card" v-model="activeName">
      <el-tab-pane label="待审核" name="1" />
      <el-tab-pane label="已通过" name="2" />
      <el-tab-pane label="未通过" name="3" />
      <el-tab-pane label="黑名单" name="4" />
    </el-tabs>
    <PendingReview v-if="activeName == '1'"/>
    <Passed v-if="activeName == '2'"/>
    <NotPass v-if="activeName == '3'"/>
    <Blacklist v-if="activeName == '4'"/>
  </div>
</template>
<script setup>
import { ref, toRefs, computed, markRaw, nextTick } from "vue";
// 待提交
import PendingReview from "./pendingReview.vue";
// 已通过
import Passed from "./passed.vue";
// 未通过
import NotPass from "./notPass.vue";
// 黑名单
import Blacklist from "./blacklist.vue";

const componentRef = ref();

const props = defineProps({
  callData: {},
});
const activeName = ref("1");

</script>
<style></style>
相关推荐
全宝13 分钟前
🌏【cesium系列】01.vue3+vite集成Cesium
前端·gis·cesium
拉不动的猪1 小时前
简单回顾下插槽透传
前端·javascript·面试
烛阴1 小时前
Fragment Shader--一行代码让屏幕瞬间变黄
前端·webgl
爱吃鱼的锅包肉1 小时前
Flutter路由模块化管理方案
前端·javascript·flutter
风清扬雨2 小时前
Vue3具名插槽用法全解——从零到一的详细指南
前端·javascript·vue.js
海盗强2 小时前
Vue 3 常见的通信方式
javascript·vue.js·ecmascript
大熊猫今天吃什么2 小时前
【一天一坑】空数组,使用 allMatch 默认返回true
前端·数据库
!win !2 小时前
Tailwind CSS一些你需要记住的原子类
前端·tailwindcss
前端极客探险家3 小时前
打造一个 AI 面试助手:输入岗位 + 技术栈 → 自动生成面试问题 + 标准答案 + 技术考点图谱
前端·人工智能·面试·职场和发展·vue
oscar9993 小时前
JavaScript与TypeScript
开发语言·javascript·typescript