vue3动态组件使用详解
更新时间:2023年02月27日 08:17:53 作者:不叫猫先生
这篇文章主要介绍了vue3动态组件使用详解的相关资料,需要的朋友可以参考下
- markRow:标记一个对象,使其不能成为一个响应式对象。
- toRaw:将响应式对象(由 reactive定义的响应式)转换为普通对象。
- shallowRef:只处理基本数据类型的响应式, 不进行对象的响应式处理。
- shallowReactive:只处理对象最外层属性的响应式(浅响应式)。
问题:为什么vue3需要对引入的组件使用markRow?
vue2
<template>
<div>
<component :is="A"></component>
</div>
</template>
<script>
import A from './A';
export default {
name: 'Home',
data() {
return {}
},
components: { A },
}vue3
<template>
<ul>
<li
v-for='(item,index) in tabList'
:key='index'
@click='change(index)'
>
{{ item.name }}
</li>
</ul>
<keep-alive>
<component :is="currentComponent"></component>
</keep-alive>
</template>
<script setup>
import A from '../components/A.vue'
import B from '../components/B.vue'
import C from '../components/C.vue'
let tabList = reactive([
{name:'组件A',com:markRaw(A)},
{name:'组件B',com:markRaw(B)},
{name:'组件C',com:markRaw(C)}
]);
let currentComponent = reactive({
com:tabList[0]
});
const change = ( idx )=>{
currentComponent = tabList[idx].com;
}到此这篇关于vue3动态组件使用详解的文章就介绍到这了,更多相关vue3动态组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Ant Design Vue Pagination分页组件的封装与使用
这篇文章主要介绍了Ant Design Vue Pagination分页组件的封装与使用方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-04-04
Vue 项目中选择 TSX 而非传统 .vue 文件的原因分析
文章探讨了Vue项目中使用TSX(TypeScript JSX)的背景、优势和局限性,TSX结合了TypeScript和JSX,增强了类型安全和代码组织性,但也增加了学习曲线和可读性问题,对于复杂应用,TSX提供了更大的灵活性和类型支持,逐渐成为一些开发者的选择2024-11-11
Vue3.0之引入Element-plus ui样式的两种方法
本文主要介绍了Vue3.0之引入Element-plus ui样式的两种方法,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2022-02-02


最新评论