Vue3中keep-alive使用及注意事项
是 Vue 内置的一个抽象组件,用于缓存不活动的组件实例,避免重复渲染,提高性能。
以下是它的详细用法和注意事项:
基本用法
- <template>
- <!-- 基本用法 -->
- <keep-alive>
- <component :is="currentComponent"></component>
- </keep-alive>
- <!-- 缓存特定组件 -->
- <keep-alive include="CompA,CompB" exclude="CompC">
- <router-view></router-view>
- </keep-alive>
- </template>
复制代码 主要功能
- 组件缓存:当组件切换时,保留组件状态(如数据、滚动位置等)
- 避免重复渲染:减少不必要的 DOM 操作和生命周期钩子执行
- 保留状态:保持表单输入内容、滚动位置等
核心属性
生命周期钩子
被缓存的组件会触发特有的生命周期钩子:
- :组件被激活时调用(进入缓存组件)
- :组件被停用时调用(离开缓存组件)
- import { onActivated, onDeactivated } from 'vue'
- export default {
- setup() {
- onActivated(() => {
- console.log('组件被激活')
- })
-
- onDeactivated(() => {
- console.log('组件被停用')
- })
- }
- }
复制代码 与 Vue Router 结合使用
- <template>
- <keep-alive :include="cachedViews">
- <router-view v-slot="{ Component }">
- <transition name="fade">
- <component :is="Component" />
- </transition>
- </router-view>
- </keep-alive>
- </template>
- <script>
- import { ref } from 'vue'
- export default {
- setup() {
- const cachedViews = ref(['Home', 'User'])
- return { cachedViews }
- }
- }
- </script>
复制代码 注意事项
组件必须有 name 选项:和匹配的是组件的选项
动态组件切换问题:
- <keep-alive><comp :key="id"></comp></keep-alive>
复制代码- <comp v-if="show"></comp>
复制代码 内存占用:
- 缓存过多组件可能导致内存占用过高
- 使用属性限制缓存数量
数据更新时机:
- 缓存的组件不会重新创建,因此/不会再次触发
- 应在中处理数据刷新逻辑
滚动行为:
- 默认会保持滚动位置
- 如需重置滚动位置,可在中处理:
- onActivated(() => {
- window.scrollTo(0, 0)
- })
复制代码 与 Transition 一起使用:- <router-view v-slot="{ Component }">
- <transition name="fade">
- <keep-alive>
- <component :is="Component" />
- </keep-alive>
- </transition>
- </router-view>
复制代码 最佳实践
- 只缓存必要的组件(如表单页、列表页)
- 对需要频繁切换但状态需要保留的组件使用
- 避免缓存大型组件或包含大量数据的组件
- 在路由元信息中管理缓存:
- const routes = [
- {
- path: '/user',
- component: User,
- meta: { keepAlive: true }
- }
- ]
复制代码 通过合理使用,可以显著提升应用性能,特别是在移动端或需要频繁切换视图的场景中。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
来源:https://www.jb51.net/javascript/339805b05.htm
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |