vue3动态组件
什么是动态组件 就是:让多个组件使用同一个挂载点,并动态切换,这就是动态组件。
在挂载点使用component标签,然后使用v-bind:is=”组件 ,通过is 切换 A B 组件
-
<template>
-
<div style="display: flex;">
-
<div @click="switchCom(item,index)"
-
:class="[active == index ? 'active':'']"
-
class="tabs" v-for="(item,index) in data" :key="index">
-
<div>{{ item.name }}</div>
-
</div>
-
</div>
-
<!-- 内置组件 -->
-
<component :is="comId"></component>
-
</template>
-
<script setup lang='ts'>
-
import { ref, reactive, shallowRef, markRaw } from 'vue'
-
import AP from '@/components/expame/AP.vue'
-
import BP from '@/components/expame/BP.vue'
-
import CP from '@/components/expame/CP.vue'
-
-
const comId = shallowRef(AP) // 切换组件
-
const active = ref(0) // 点击tab动态样式
-
const data = reactive([
-
{
-
name:'A组件',
-
com:markRaw(AP)
-
},
-
{
-
name:'B组件',
-
com:markRaw(BP)
-
},
-
{
-
name:'C组件',
-
com:markRaw(CP)
-
}
-
])
-
// 点击事件
-
const switchCom = (item , index) => {
-
comId.value = item.com
-
active.value = index
-
}
-
</script>
使用场景
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 或者 shallowRef 跳过proxy 代理
所以上面要使用shallowRef , shallowRef 包裹组件
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhgbehfc
系列文章
更多
同类精品
更多
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
怎样阻止微信小程序自动打开
PHP中文网 06-13 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01