Vue路由开启keep-alive缓存页面

Posted neo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue路由开启keep-alive缓存页面相关的知识,希望对你有一定的参考价值。

mode:hash模式下:

html部分:

<template>
  <div id="app">
   <keep-alive>     <!--使用keep-alive会将页面缓存-->
    <router-view v-if="$route.meta.keepAlive"></router-view>
   </keep-alive>  
     <router-view v-if="!$route.meta.keepAlive"></router-view>
  </div>
</template>

 路由部分:

{
	path: ‘/home‘,
	name: ‘首页‘,
	menuShow: true,
	iconCls: ‘home_light.svg‘,
	component: Home,
	meta:{keepAlive:true}
}
页面部分:
//缓存页面
beforeRouteLeave(to, from, next) {    
   // 设置下一个路由的 meta
    to.meta.keepAlive = true; // B 跳转到 A 时,让 A 缓存,即不刷新(代码写在B页面)
    next();
   }



//不缓存页面
beforeRouteLeave(to, from, next) {    
   // 设置下一个路由的 meta
    to.meta.keepAlive = false; // B 跳转到 A 时,让 A 不缓存,即刷新(代码写在B页面)
    next();
   }

  

  

 

以上是关于Vue路由开启keep-alive缓存页面的主要内容,如果未能解决你的问题,请参考以下文章

vue 路由缓存 keep-alive include和exclude无效

vue 路由缓存 keep-alive include和exclude无效

vue中tab标签页keep-alive二级路由+删除指定缓存页面

Vue keep-alive本地路由缓存和图片懒加载

vue 路由缓存

Vue路由器使用keep-alive缓存某些组件?