路由的缓存 keep-alive

本文讲述了作者在使用Vue3和element-plus开发政府留言功能时,如何实现路由缓存以保持用户在详情页返回时仍停留在原tabs下,并介绍了keep-alive组件的activated和deactivated钩子在缓存组件状态管理中的应用。
摘要由CSDN通过智能技术生成

最近做到一个小deomo,政府相关的留言功能,我用的vue3的框架,element-plus组件库,用到tabs,分页,表单组件,需要有分页,点击查看详情,有两种状态,办理中,已回复,当时我做到跳转详情的时候,做到返回主页面,我想要的结果是,在当前页面下的tabs下点击详情后,返回过来,不会发起请求。位置就在当前点击的位置。

 <router-view v-slot="{ Component }">
      <keep-alive :include="['Home']">
        <component :is="Component" />
      </keep-alive>
  </router-view>

include里放的是需要缓存的路由,exclude里放的是不要缓存的路由

 path: '/home', name: 'Home', component: () => import('../views/Home/Index.vue')

这是我路由配置,我开始以为这样就能生效,结果不能。

在vue3这样并不能生效,还需要在页面使用name值才能生效

<script>
export default {
  name: "Home",
};
</script>

这里就是vue2的写法,我就没想到,哈哈,不过最终还是实现了----我这只是个小deomo所以写的比较简单,若在一整个项目中,则需要一般在路由mata中配置,通过v-if来判断,有很多方式的,这里就不一一演示了

另外它还有两个生命周期

当使用 keep-alive 组件缓存一个组件时,如果需要在组件被缓存时执行一些操作,可以使用 activated 钩子函数,在组件被激活(被缓存并且被展示)时触发。如果需要在组件被缓存时清除一些数据或状态,可以使用 deactivated 钩子函数,在组件被停用(被缓存但不被展示)时触发。
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清爽豆干

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值