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(); }