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