Vue3中keep-alive的使用及注意事项说明

 更新时间:2025年04月17日 10:55:06   作者:大樊子  
这篇文章主要介绍了Vue3中keep-alive的使用及注意事项说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Vue3中keep-alive使用及注意事项

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 操作和生命周期钩子执行
  • 保留状态:保持表单输入内容、滚动位置等

核心属性

生命周期钩子

keep-alive 缓存的组件会触发特有的生命周期钩子:

  • onActivated:组件被激活时调用(进入缓存组件)
  • onDeactivated:组件被停用时调用(离开缓存组件)
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 选项includeexclude 匹配的是组件的 name 选项

动态组件切换问题

  • 使用 key 属性强制重新渲染:
<keep-alive><comp :key="id"></comp></keep-alive>
  • 或者使用 v-if 控制:
<comp v-if="show"></comp>

内存占用

  • 缓存过多组件可能导致内存占用过高
  • 使用 max 属性限制缓存数量

数据更新时机

  • 缓存的组件不会重新创建,因此 created/mounted 不会再次触发
  • 应在 activated 中处理数据刷新逻辑

滚动行为

  • 默认会保持滚动位置
  • 如需重置滚动位置,可在 activated 中处理:
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 }
  }
]

通过合理使用 keep-alive,可以显著提升应用性能,特别是在移动端或需要频繁切换视图的场景中。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 浅谈sass在vue注意的地方

    浅谈sass在vue注意的地方

    下面小编就为大家带来一篇浅谈sass在vue注意的地方。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • Vue中使用webpack别名的方法实例详解

    Vue中使用webpack别名的方法实例详解

    本文通过实例给大家介绍了Vue中使用webpack别名的方法,非常不错,具体一定的参考借鉴价值,需要的朋友可以参考下
    2018-06-06
  • 使用Vue做一个简单的todo应用的三种方式的示例代码

    使用Vue做一个简单的todo应用的三种方式的示例代码

    这篇文章主要介绍了使用Vue做一个简单的todo应用的三种方式的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • VUE项目运行失败原因及解决办法图解(以vscode为例)

    VUE项目运行失败原因及解决办法图解(以vscode为例)

    记录一下踩坑,前几天从同事手上接手了一个Vue的项目,下面这篇文章主要给大家介绍了关于VUE项目运行失败原因及解决办法的相关资料,本文以vscode为例,需要的朋友可以参考下
    2023-06-06
  • Vue父子组件传值&自定义事件方式

    Vue父子组件传值&自定义事件方式

    这篇文章主要介绍了Vue父子组件传值&自定义事件方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Vue.js进行查询操作的实例详解

    Vue.js进行查询操作的实例详解

    这篇文章主要介绍了Vue.js进行查询操作的实例详解的相关资料,需要的朋友可以参考下
    2017-08-08
  • Element Tooltip 文字提示的使用示例

    Element Tooltip 文字提示的使用示例

    这篇文章主要介绍了Element Tooltip 文字提示的使用示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • vue中jsonp的使用方法

    vue中jsonp的使用方法

    这篇文章主要介绍了vue中jsonp的使用方法,文章从安装开始展开具体的vue中jsonp的使用详细内容,需要的朋友可以参考一下,希望对大家有所帮助
    2021-11-11
  • Vue封装数字框组件实现流程详解

    Vue封装数字框组件实现流程详解

    这篇文章主要介绍了Vue封装数字框组件实现流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2023-04-04
  • vue-awesome-swiper 基于vue实现h5滑动翻页效果【推荐】

    vue-awesome-swiper 基于vue实现h5滑动翻页效果【推荐】

    说到h5的翻页,很定第一时间想到的是swiper。但是我当时想到的却是,vue里边怎么用swiper。这篇文章主要介绍了vue-awesome-swiper - 基于vue实现h5滑动翻页效果 ,需要的朋友可以参考下
    2018-11-11

最新评论