keep-alive缓存

#keep-alive缓存动态路由的使用指南#

代码如下图 :

javascript 复制代码
<router-view v-slot="{ Component }">    
    <keep-alive :include="['Hot', 'Notifications', 'User', 'Setting', 'Test']">                    
        <component :is="Component"  />
    </keep-alive>
</router-view>

讲解:

一、v-slot="{ Component }" 的作用

这是 Vue 的作用域插槽语法 ,用于从 <router-view> 中获取当前路由对应的组件实例。

具体解释:
  1. <router-view> 的职责

    Vue Router 的 <router-view> 是一个动态容器,会根据当前路由路径渲染对应的组件(例如 /home 渲染 HomeComponent/about 渲染 AboutComponent)。

  2. 作用域插槽的暴露

    通过 v-slot="{ Component }"<router-view> 会将当前匹配到的组件实例以 Component 变量的形式暴露给父组件。

  3. 为何需要这个语法?

    为了在 <router-view> 外层包裹其他逻辑(如添加动画、缓存控制等),需要先获取到当前路由对应的组件实例,再手动渲染它。

二、:is="Component" 的作用

这是 Vue 的动态组件语法,用于动态决定要渲染哪个组件。

具体解释:
  1. <component> 元素

    Vue 内置的 <component> 是一个特殊元素,它通过 :is 属性绑定要渲染的组件。

  2. 与路由结合

    在路由场景中,Component 是从 <router-view> 的作用域插槽中获取的当前路由组件。等价于直接渲染 <router-view> 的内容,但通过这种写法可以添加额外逻辑(例如包裹 <keep-alive>)。

三、include 的作用

1. 核心功能
  • 缓存白名单include 接受一个组件名称的数组 (字符串或正则表达式),只有匹配名称的组件才会被 <keep-alive> 缓存。

  • 避免重复渲染 :被缓存的组件切换时不会触发 onMounted 生命周期,而是通过 onActivated/onDeactivated 管理状态。

2. 必须匹配组件的 name 选项
  • 组件定义时必须显式声明 name

    被缓存的组件需要在其选项中明确设置 name 字段

Tip:

一个小tip,如果要保持路由缓存,相关跳转不要用a标签,用route.push(),不然会导致路由重新加载

相关推荐
哎哟喂_!29 分钟前
Node.js 同步加载问题详解:原理、危害与优化策略
前端·chrome·node.js
__BMGT()31 分钟前
C++ QT图片查看器
前端·c++·qt
OK_boom1 小时前
React-useRef
javascript·react.js·ecmascript
未来之窗软件服务1 小时前
solidwors插件 开发————仙盟创梦IDE
前端·javascript·数据库·ide·仙盟创梦ide
小白学大数据1 小时前
基于Scrapy-Redis的分布式景点数据爬取与热力图生成
javascript·redis·分布式·scrapy
Varpb1 小时前
【vue】【环境配置】项目无法npm run serve,显示node版本过低
前端·vue.js·npm
Kookoos2 小时前
Redis + ABP vNext 构建分布式高可用缓存架构
redis·分布式·缓存·架构·c#·.net
读心悦2 小时前
CSS 溢出内容处理、可见性控制与盒类型设置深度解析
前端·css
Minyy112 小时前
Vue3指令(二)--v-text、v-html数据渲染,计算属性
前端·javascript·vue.js·前端框架·vue·html
个人开发-胡涂涂2 小时前
ECMAScript标准:JavaScript的核心
前端·javascript·ecmascript