什么是动态组件 就是:让多个组件使用同一个挂载点,并动态切换,这就是动态组件。
    在挂载点使用component标签,然后使用v-bind:is=”组件”
    用法如下
    引入组件

    1. import A from './A.vue'
    2. import B from './B.vue'
    1. <component :is="A"></component>

    通过is 切换 A B 组件
    使用场景
    tab切换 居多
    注意事项
    1.在Vue2 的时候is 是通过组件名称切换的 在Vue3 setup 是通过组件实例切换的
    2.如果你把组件实例放到Reactive Vue会给你一个警告runtime-core.esm-bundler.js:38 [Vue warn]: Vue received a Component which was made a reactive object. This can lead to unnecessary performance overhead, and should be avoided by marking the component with markRaw or using shallowRef instead of ref.
    Component that was made reactive:
    这是因为reactive 会进行proxy 代理 而我们组件代理之后毫无用处 节省性能开销 推荐我们使用shallowRef 或者 markRaw 跳过proxy 代理
    修改如下

    1. const tab = reactive<Com[]>([{
    2. name: "A组件",
    3. comName: markRaw(A)
    4. }, {
    5. name: "B组件",
    6. comName: markRaw(B)
    7. }])