0

0

Vue的keep-alive组件是如何缓存组件的?

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-08-21 08:04:01

|

283人浏览过

|

来源于php中文网

原创

vue 的 keep-alive 组件是一个抽象组件,不会渲染为真实 dom,主要用于缓存动态切换的组件以提升性能。1. 它通过保存组件实例到内存中而非销毁,实现组件切换时的状态保留,并在激活和失活时分别触发 activated 和 deactivated 生命周期钩子;2. 可通过 include 和 exclude 属性控制缓存策略,仅缓存指定组件或排除特定组件,但需确保组件设置了 name 属性;3. 使用 keep-alive 可能带来状态不重置、视图不刷新等问题,需在 activated 中刷新数据,在 deactivated 中清理资源如定时器,以避免副作用。

Vue的keep-alive组件是如何缓存组件的?

Vue 的

keep-alive
组件其实是一个抽象组件,它本身不会渲染成真实的 DOM 元素。它的作用是缓存内部动态切换的组件,避免重复创建和销毁,从而提升性能。

简单来说,当使用

包裹一个动态组件(比如通过
component is
动态切换的组件)时,Vue 会把这些被切换出去的组件保留在内存中,而不是直接销毁它们。这样在下次切换回来的时候,就可以直接复用之前的状态,不需要重新加载或初始化。

下面是一些关键点和使用建议:

立即学习前端免费学习笔记(深入)”;


1.
keep-alive
是如何工作的?

keep-alive
主要是通过 Vue 内部的组件实例管理机制来实现的。当你在
中包裹一个组件并切换它时,Vue 并不会真正卸载这个组件,而是将其从 DOM 中移除,并保存其组件实例到内存中。

  • 切换进来时触发
    activated
    钩子
  • 切换出去时触发
    deactivated
    钩子

这两个生命周期钩子非常适合做一些资源控制或者状态保存的操作。

举个例子:


  

在这个结构中,如果你有两个 tab 组件 A 和 B,切换到 B 的时候,A 不会被销毁,而是进入“缓存”状态。

JTBC网站内容管理系统5.0.3.1
JTBC网站内容管理系统5.0.3.1

JTBC CMS(5.0) 是一款基于PHP和MySQL的内容管理系统原生全栈开发框架,开源协议为AGPLv3,没有任何附加条款。系统可以通过命令行一键安装,源码方面不基于任何第三方框架,不使用任何脚手架,仅依赖一些常见的第三方类库如图表组件等,您只需要了解最基本的前端知识就能很敏捷的进行二次开发,同时我们对于常见的前端功能做了Web Component方式的封装,即便是您仅了解HTML/CSS也

下载

2. 控制哪些组件需要缓存:
include
exclude

有时候我们并不想缓存所有组件,这时候可以使用

include
exclude
属性来精确控制:

  • include
    :只有匹配的组件名才会被缓存
  • exclude
    :匹配的组件不会被缓存

例如:


  
export default {
  components: {
    TabA,
    TabB
  }
}

如果只想缓存

TabA
,可以这样写:


  

注意:组件必须设置了

name
属性才能被正确识别。


3. 缓存带来的副作用与处理方式

虽然

keep-alive
能提高性能,但也可能带来一些副作用,比如:

  • 页面状态不会重置(比如表单输入、异步数据)
  • 数据更新后视图不刷新(因为组件没有重新创建)

所以使用时需要注意:

  • activated
    钩子中做必要的刷新操作
  • deactivated
    钩子中清理定时器或取消订阅等操作

举个例子:

activated() {
  this.fetchData(); // 每次激活时重新拉取数据
},
deactivated() {
  clearInterval(this.timer); // 清理定时器
}

基本上就这些。

keep-alive
的机制不算复杂,但理解清楚它的生命周期和适用场景,能帮助我们在开发中更好地优化体验。

相关文章

keep
keep

Keep是一款健身安排,无论是想减肥塑形或增肌,还是寻找健身跑步瑜伽计步等训练计划,你可以随时随地选择课程进行训练!权威教练视频教学,健身干货自由分享!有需要的小伙伴快来保存下载体验吧!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

3171

2024.08.14

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

8

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

24

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

18

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

18

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.22

PHP特殊符号教程合集
PHP特殊符号教程合集

本专题整合了PHP特殊符号相关处理方法,阅读专题下面的文章了解更多详细内容。

9

2026.01.22

PHP探针相关教程合集
PHP探针相关教程合集

本专题整合了PHP探针相关教程,阅读专题下面的文章了解更多详细内容。

7

2026.01.22

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

28

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Vue 教程
Vue 教程

共42课时 | 7万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号