2022-01-08 17:20:46 +08:00
|
|
|
<template>
|
2022-03-04 16:44:33 +08:00
|
|
|
<router-view v-slot="{ Component, route }">
|
|
|
|
<transition name="fade-slide" mode="out-in" appear>
|
|
|
|
<keep-alive :include="keepAliveRouteNames">
|
|
|
|
<component :is="Component" :key="route.path" />
|
|
|
|
</keep-alive>
|
|
|
|
</transition>
|
2022-01-08 17:20:46 +08:00
|
|
|
</router-view>
|
|
|
|
</template>
|
2022-03-04 16:44:33 +08:00
|
|
|
|
|
|
|
<script setup>
|
|
|
|
import { computed } from 'vue'
|
|
|
|
import { useRouter } from 'vue-router'
|
|
|
|
const router = useRouter()
|
|
|
|
const allRoutes = router.getRoutes()
|
|
|
|
const keepAliveRouteNames = computed(() => {
|
|
|
|
return allRoutes.filter((route) => route.meta?.keepAlive).map((route) => route.name)
|
|
|
|
})
|
|
|
|
</script>
|