|
1
|
<template>
|
vben
authored
|
2
|
<div v-if="showFrame">
|
vben
authored
|
3
4
5
6
7
8
9
10
|
<template v-for="frame in getFramePages" :key="frame.path">
<FramePage
v-if="frame.meta.frameSrc && hasRenderFrame(frame.name)"
v-show="showIframe(frame)"
:frameSrc="frame.meta.frameSrc"
/>
</template>
</div>
|
|
11
12
|
</template>
<script lang="ts">
|
vben
authored
|
13
|
import { defineComponent, unref, computed } from 'vue';
|
|
14
|
import FramePage from '/@/views/sys/iframe/index.vue';
|
vben
authored
|
15
16
17
|
import { useFrameKeepAlive } from './useFrameKeepAlive';
|
|
18
19
20
21
|
export default defineComponent({
name: 'FrameLayout',
components: { FramePage },
setup() {
|
vben
authored
|
22
23
|
const { getFramePages, hasRenderFrame, showIframe } = useFrameKeepAlive();
|
vben
authored
|
24
|
const showFrame = computed(() => unref(getFramePages).length > 0);
|
vben
authored
|
25
26
|
return { getFramePages, hasRenderFrame, showIframe, showFrame };
|
|
27
28
29
|
},
});
</script>
|