vue3动态组件

 

      
           <!-- 动态组件 -->
            <component
              :is="components.get(activeKey)"
            />

 

复制代码
 import { defineAsyncComponent, markRaw } from 'vue';
 const components = markRaw(new Map<string, any>());
  //组件1
  components.set(
    'index1',
    defineAsyncComponent(() => import('./components/table/index1.vue')),
  );
  //组件2
  components.set(
    'index12',
    defineAsyncComponent(() => import('./components/table/index2.vue')),
  );
  //后端返回数据
  const carBarList = ref([
    {
      name: '组件1',
      sign: 'index1',
      icon: 'icon-icon-hengxiangshijianzhou',
    },
    {
      name: '组件2',
      sign: 'index2',
      icon: 'icon-wj-jdws',
    },
  ]);
  //组件切换标识
   const activeKey = ref('');
  //组件选择
  function tabSelect(item: { sign: string }) {
    activeKey.value = item.sign;
  }
复制代码
//keep-alive钩子函数:组件被激活时调用
  activated() {
    console.log('组件被激活');
  },
  //keep-alive钩子函数:组件消失,被缓存时调用
  deactivated() {
    console.log('组件被缓存');
  },

 

 

 

 

 

参考

https://blog.csdn.net/zhouoxinxin/article/details/126263418

posted @   王希有  阅读(485)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示