|
|
|
@ -7,6 +7,8 @@ |
|
|
|
|
</template> |
|
|
|
|
|
|
|
|
|
<script lang="ts"> |
|
|
|
|
import { CacheEnum } from '@/enums' |
|
|
|
|
import { VisualEditorModelValue } from '@/visual-editor/visual-editor.utils' |
|
|
|
|
import { defineComponent, ref, watch } from 'vue' |
|
|
|
|
import { useRoute } from 'vue-router' |
|
|
|
|
|
|
|
|
@ -15,14 +17,26 @@ export default defineComponent({ |
|
|
|
|
setup() { |
|
|
|
|
const keepAliveRef = ref() |
|
|
|
|
const route = useRoute() |
|
|
|
|
const jsonData: VisualEditorModelValue = JSON.parse( |
|
|
|
|
localStorage.getItem(CacheEnum.PAGE_DATA_KEY) as string |
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
// 不需要缓存的页面 |
|
|
|
|
const notNeedcachePages = Object.keys(jsonData.pages).filter( |
|
|
|
|
(key) => !jsonData.pages[key].config.keepAlive |
|
|
|
|
) |
|
|
|
|
console.log('notNeedcachePages:', notNeedcachePages) |
|
|
|
|
|
|
|
|
|
watch( |
|
|
|
|
() => route.fullPath, |
|
|
|
|
() => { |
|
|
|
|
// 获取keep-alive缓存 |
|
|
|
|
const routeCaches = keepAliveRef.value?.$?.__v_cache |
|
|
|
|
console.log('keep-alive cache', routeCaches) |
|
|
|
|
routeCaches.delete('/') |
|
|
|
|
() => route.path, |
|
|
|
|
(path) => { |
|
|
|
|
if (notNeedcachePages.includes(path)) { |
|
|
|
|
// 获取keep-alive缓存 |
|
|
|
|
const routeCaches = keepAliveRef.value?.$?.__v_cache |
|
|
|
|
console.log('keep-alive cache', path, routeCaches) |
|
|
|
|
// 从keep-alive的缓存中删除不需要缓存的路由 |
|
|
|
|
routeCaches.delete(path) |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
) |
|
|
|
|
|
|
|
|
|