在Vue3中实现缓存和复用动态组件
在 Vue 3 中,如何缓存和复用动态组件,这有助于提高应用的性能,避免组件重复创建和销毁带来的开销。
下面详细介绍其使用方法和相关配置。
1. 使用<KeepAlive>组件缓存动态组件
基本使用
<KeepAlive> 是 Vue 3 内置的一个组件,它可以将包裹在其中的动态组件进行缓存,当组件被切换隐藏时,其状态会被保留,再次显示时无需重新创建。
<template>
<div>
<button @click="currentComponent = 'ComponentA'">显示组件 A</button>
<button @click="currentComponent = 'ComponentB'">显示组件 B</button>
<!-- 使用 KeepAlive 包裹动态组件 -->
<KeepAlive>
<component :is="currentComponent" />
</KeepAlive>
</div>
</template>
<script setup>
import { ref } from 'vue';
import ComponentA from './ComponentA.vue';
import ComponentB from './ComponentB.vue';
const currentComponent = ref('ComponentA');
const components = {
ComponentA,
ComponentB
};
</script>
代码解释
- 在模板中,使用
<KeepAlive>组件包裹<component :is="currentComponent" />,这样ComponentA和ComponentB在切换时会被缓存。 currentComponent是一个响应式变量,用于控制显示哪个组件。
包含和排除特定组件
你可以使用 include 和 exclude 属性来指定哪些组件需要被缓存或排除。这两个属性的值可以是组件名称的字符串、正则表达式或数组。
<template>
<div>
<button @click="currentComponent = 'ComponentA'">显示组件 A</button>
<button @click="currentComponent = 'ComponentB'">显示组件 B</button>
<!-- 只缓存 ComponentA -->
<KeepAlive include="ComponentA">
<component :is="currentComponent" />
</KeepAlive>
</div>
</template>
<script setup>
import { ref } from 'vue';
import ComponentA from './ComponentA.vue';
import ComponentB from './ComponentB.vue';
const currentComponent = ref('ComponentA');
const components = {
ComponentA,
ComponentB
};
</script>
代码解释
include="ComponentA"表示只有ComponentA会被缓存,ComponentB不会被缓存,每次切换到ComponentB时都会重新创建。- 若使用
exclude属性,则与之相反,被排除的组件不会被缓存。例如<KeepAlive exclude="ComponentB">会缓存除ComponentB之外的组件。
最大缓存实例数
你可以使用 max 属性来限制 <KeepAlive> 缓存的最大实例数量。当缓存的实例数量超过 max 值时,最早缓存的实例会被销毁。
<template>
<div>
<button @click="currentComponent = 'ComponentA'">显示组件 A</button>
<button @click="currentComponent = 'ComponentB'">显示组件 B</button>
<button @click="currentComponent = 'ComponentC'">显示组件 C</button>
<!-- 最多缓存 2 个组件实例 -->
<KeepAlive max="2">
<component :is="currentComponent" />
</KeepAlive>
</div>
</template>
<script setup>
import { ref } from 'vue';
import ComponentA from './ComponentA.vue';
import ComponentB from './ComponentB.vue';
import ComponentC from './ComponentC.vue';
const currentComponent = ref('ComponentA');
const components = {
ComponentA,
ComponentB,
ComponentC
};
</script>
代码解释
max="2"表示<KeepAlive>最多缓存 2 个组件实例。当切换到第三个组件时,最早缓存的组件实例会被销毁。
组件缓存状态的生命周期钩子
当组件被 <KeepAlive> 缓存时,会有两个特殊的生命周期钩子 onActivated 和 onDeactivated,可以在这两个钩子中执行相应的逻辑。
<template>
<div>
This is Component A.
</div>
</template>
<script setup>
import { onActivated, onDeactivated } from 'vue';
onActivated(() => {
console.log('Component A is activated.');
});
onDeactivated(() => {
console.log('Component A is deactivated.');
});
</script>
代码解释
onActivated:当组件被激活(从缓存中显示出来)时触发。onDeactivated:当组件被停用(被隐藏并放入缓存)时触发。
通过上述方法,你可以在 Vue 3 中灵活地缓存和复用动态组件,提高应用的性能和用户体验。
2. 组件实例缓存(手动管理)
除了使用 <KeepAlive>,你还可以手动管理组件实例的缓存。通过一个对象来存储组件实例,在需要使用时从对象中获取。
<template>
<div>
<button @click="showComponent('ComponentA')">显示组件 A</button>
<button @click="showComponent('ComponentB')">显示组件 B</button>
<component :is="currentComponent" v-if="currentComponent" />
</div>
</template>
<script setup>
import { ref, shallowRef, markRaw } from 'vue';
import ComponentA from './ComponentA.vue';
import ComponentB from './ComponentB.vue';
// 存储组件实例的缓存对象
const componentCache = {};
const currentComponent = ref(null);
const showComponent = (name) => {
if (!componentCache[name]) {
const component = name === 'ComponentA' ? ComponentA : ComponentB;
// 创建组件实例并存储到缓存中
componentCache[name] = markRaw(shallowRef(component));
}
currentComponent.value = componentCache[name].value;
};
</script>
代码解释
componentCache是一个对象,用于存储组件实例。showComponent方法根据传入的组件名称,检查缓存中是否存在该组件实例。如果不存在,则创建实例并存储到缓存中;如果存在,则直接从缓存中获取。
3. 组合式函数封装
可以将动态组件的逻辑封装到组合式函数中,提高代码的复用性。
// useDynamicComponent.js
import { ref, shallowRef, markRaw } from 'vue';
export function useDynamicComponent() {
const componentCache = {};
const currentComponent = ref(null);
const showComponent = (name, component) => {
if (!componentCache[name]) {
componentCache[name] = markRaw(shallowRef(component));
}
currentComponent.value = componentCache[name].value;
};
return {
currentComponent,
showComponent
};
}
<template>
<div>
<button @click="showComponent('ComponentA', ComponentA)">显示组件 A</button>
<button @click="showComponent('ComponentB', ComponentB)">显示组件 B</button>
<component :is="currentComponent" v-if="currentComponent" />
</div>
</template>
<script setup>
import { useDynamicComponent } from './useDynamicComponent.js';
import ComponentA from './ComponentA.vue';
import ComponentB from './ComponentB.vue';
const { currentComponent, showComponent } = useDynamicComponent();
</script>
代码解释
useDynamicComponent组合式函数封装了动态组件的缓存和显示逻辑。- 在组件中使用该组合式函数,通过调用
showComponent方法来显示不同的组件。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Vue3实现Element Plus表格的多选功能与条件操作
Element-plus是ElementUI的升级版,是一套基于vue2与vue3的桌面端组件库,它提供了丰富的组件帮助开发人员快速构建功能强大、风格统一的页面,本文给大家介绍了Vue3实现Element Plus表格的多选功能与条件操作,需要的朋友可以参考下2024-08-08
Vue中使用v-model双向数据绑定select、checked等多种表单元素的方法
v-model 指令可以用在表单 input、textarea 及 select 元素上创建双向数据绑定,它会根据控件类型自动选取正确的方法来更新元素,本文给大家介绍Vue中如何使用v-model双向数据绑定select、checked等多种表单元素,感兴趣的朋友一起看看吧2023-10-10
ElementUi中select框在页面滚动时el-option超出元素区域的问题解决
本文主要介绍了ElementUi中select框在页面滚动时el-option超出元素区域的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2024-08-08
vue cli 3.x 项目部署到 github pages的方法
这篇文章主要介绍了vue cli 3.x 项目部署到 github pages的方法,非常不错,具有一定的参考借鉴价值 ,需要的朋友可以参考下2019-04-04
Vue3解决Mockjs引入后并访问404(Not Found) 的页面报错问题
mock.js:是一款模拟数据生成器,可以生成随机数据,拦截 Ajax 请求,使用mockjs模拟后端接口,可随机生成所需数据,模拟对数据的增删改查,本文给大家介绍了Vue3解决Mockjs引入后并访问404(Not Found) 的页面报错问题,需要的朋友可以参考下2025-04-04


最新评论