keep-alive 缓存页面

在实际开发中需要做页面缓存,分很多种情况.比如只缓存页面,不分任何页面跳转过去,数据都保留离开之前的. 或者,只有去某一个页面,返回数据才保留,去其余页面,返回来数据清空或者初始化数据

一. 只需要缓存某个页面

1.首先再router.js 路由里面配置去配置

//在需要缓存的页面路由文件配上keep-alive 
{
    path: '/',
    name: 'Home',
    component: Home,
    meta:{
        keepAlive:true,//判断是否缓存 true 为缓存 false 不缓存
     }
  },

2.在你入口文件App.vue配置.判断keepAlive是true还是false .

//在入口文件App.vue 去判断
<keep-alive> 

      <router-view  v-if="$router.meta.keepAlive" />

</keep-alive>

<router-view  v-if="!$router.meta.keepAlive" />

此时需要需要缓存的页面已经做到了缓存

二.只去某一个页面,数据才缓存.去其他页面不缓存

比如:

 A页面是我们需要缓存的页面 => 去到B页面 =>B页面在返回来数据是没变的

 A页面 =>去到其他页面(如:C,D,E页面) => 在返回A页面,数据初始化或者清空变化了

其实整个思路是 A页面一直做了缓存,只是通过路由钩子做了判断去的哪一个页面,然后再对数据做了处理

1.第一部分操作,和上面的一样,然后第三步

//再需要缓存的A页面写  beforeRouteLeave 离开当前页面触发的路由钩子 因为我们目前的功能是A页面初次进去是没有数据的

 beforeRouteLeave(to,from,next){
  if(to.name !== 'B页面'){ // 判断我从A页面去的不是B页面  
    
       this.table =[]    //把表格数据清空  
    
   }
  
}

最后结果就是,除了从B页面返回A页面是有数据的,其余去A页面表格都是没有数据的

注意:

本身针对于keep-alive 有自身的生命周期,有其余功能可以在这里面去写

  1. activated: 页面第一次进入的时候,钩子触发的顺序是created->mounted->activated
  2. deactivated:  页面退出的时候会触发deactivated,当再次前进或者后退的时候只触发activated

因为项目做的事此功能,想到的方法暂时这个.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

shumabaobei1214

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

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

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

打赏作者

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

抵扣说明:

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

余额充值