Vue3动态生成组件
在 Vue 3 中,要遍历 funConfig
并动态生成组件,可以使用 Vue 的 defineAsyncComponent
来加载异步组件,并结合 v-for
指令在模板中进行渲染。
以下是一个示例代码来实现这个需求:
1. 配置文件
确保配置文件导出的是一个 reactive
对象:
import { reactive, markRaw, defineAsyncComponent } from 'vue';
export const funConfig = reactive([
{
name: '航线规划',
icon: 'fun-route',
show: false,
component: markRaw(
defineAsyncComponent(() => import('@/views/Map/components/RouteBox/index.vue')),
),
},
{
name: '海洋气象',
icon: 'fun-weather',
show: false,
component: markRaw(
defineAsyncComponent(() => import('@/views/Map/components/SeaCurrent/index.vue')),
),
},
{
name: '船舶过滤',
icon: 'fun-ship',
show: false,
component: markRaw(
defineAsyncComponent(() => import('@/views/Map/components/ShipBox/index.vue')),
),
},
{
name: '港口过滤',
icon: 'fun-port',
show: false,
component: markRaw(
defineAsyncComponent(() => import('@/views/Map/components/PortBox/index.vue')),
),
},
]);
2. Vue 组件
在 Vue 组件中,使用 defineAsyncComponent
来动态加载组件,并使用 v-for
指令来遍历 funConfig
:
<template>
<div>
<component
v-for="item in funConfig"
v-model="item.show"
:is="item.show ? item.component : null"
></component>
</div>
</template>
<script setup>
import { funConfig } from './path/to/your/config/file';
</script>
直接在component循环,可能会存在错误,使用以下方式应该可以避免
<template v-for="item in funConfig">
<component v-model="item.show" v-if="item.show" :is="item.component"></component>
</template>
分类:
前端 / Vue学习
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!