动态组件

动态组件

import A from './A.vue'
import B from './B.vue'
import C from './C.vue'
import { markRaw, reactive } from 'vue'
type Tabs = {
  name: string
  comName: any
}
type Com = Pick<Tabs, 'comName'> // 从类型定义的属性中,选取指定一组属性,返回一个新的类型定义。

const data = reactive<Tabs[]>([
  {
    name: '我是a组件',
    comName: markRaw(A) // 标记一个对象,使其不能成为一个响应式对象。
  },
  {
    name: '我是B组件',
    comName: markRaw(B)
  },
  {
    name: '我是C组件',
    comName: markRaw(C)
  }
])
const current = reactive<Com>({
  comName: data[0].comName
})
const handleChangeTab = (item: Com) => {
  current.comName = item.comName
}
// <component is="A"></component> // vue2写法, 在vue3 setup中不能渲染 必须采用实例
<component :is="current.comName"></component>
posted @   前端之旅  阅读(29)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示