销毁

如果需要销毁已缓存的页面组件,可以使用 destroy 来进行销毁

  • destroy 属性跟方法参数为 Route.name String | Array,唯一特殊值: ALL 销毁全部
  • 在Vue实例中提供$keepRouter全局对象

在Vue实例内部销毁

<router-link :to="{name: 'Home', destroy: 'About'}">
  跳转到Home页面,并销毁About页面
</router-link>

<button @click="$router.replace({name: 'Home', destroy: 'About'})">
  跳转到Home页面,并销毁About页面
<button>

<button @click="$router.push({name: 'Home', destroy: ['Page1', 'Page2']})">
  跳转到Home页面,并销毁Page1、Page2页面
<button>

<button @click="$router.push({name: 'Home', destroy: 'ALL'})">
  跳转到Home页面,并销毁全部缓存页面
<button>

<button @click="$router.reLaunch({name: 'Home'})">
  跳转到Home页面,并销毁全部缓存页面
<button>

<button
  @click="() => {
    $router.push({name: 'Home'});
    $keepRouter.destroy('About');
  }"
>跳转到Home页面,并销毁About页面<button>

在拿不到Vue实例外销毁

import { destroy } from 'vue-with-keep-alive';

destroy(['Page1', 'Page2']);