vue3动态加载组件

如何在Vue3中动态加载组件

需求根据下拉框的值,加载不同的组件
新建文件aaa.vue,bbb.vue

<template>
  <div class="container">
    我是bbbb组件
  </div>
</template>

<script lang="ts" setup name="taskPush">
</script>
<style scoped lang="less">
</style>

aaa组件

<template>
  <div class="container">
    我是aaa组件
  </div>
</template>

<script lang="ts" setup name="taskPush">
</script>
<style scoped lang="less">
</style>

新建.ts文件

import { shallowRef } from 'vue';
export default function () {
  const asyncComponent: any = shallowRef({}); //渲染的表单组件(异步加载)
  /**
   * 获取calssify下的某一个组件
   * @param moduleName 组件名称
   */
  const getFormComponents = (moduleName: string) => {
    import(`./${moduleName}.vue`).then((module: any) => {
      asyncComponent.value = module.default;
    });
  };
  return {
    getFormComponents,
    asyncComponent
  };
}

在父组件中使用

<template>
  <div class="container">
    <el-select
      v-model="value"
      placeholder="Select"
      size="large"
      style="width: 240px"
      @change='changeCom'
    >
      <el-option
        v-for="item in options"
        :key="item.value"
        :label="item.label"
        :value="item.value"
      />
    </el-select>
    <component
      :is="asyncComponent"
      ref="componentRef"
    ></component>
  </div>
</template>

<script lang="ts" setup >
import { ref } from 'vue'
import getModuleList from "./getModuleList";
const { getFormComponents, asyncComponent } = getModuleList();
const value = ref('')

const options = [
  {
    value: 'aaa',
    label: '组件',
  },
  {
    value: 'bbb',
    label: '组件bbb',
  },
]
const changeCom = (e:any)=>{

}

</script>
<style scoped lang="less">
</style>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值