Files
my-spring/web-vue/packages/core/layouts/iframe/index.vue
2026-03-19 10:57:24 +08:00

26 lines
819 B
Vue

<template>
<div v-if="showFrame">
<template v-for="frame in getFramePages" :key="frame.path">
<FramePage v-if="frame.meta.frameSrc && hasRenderFrame(frame.name)" v-show="showIframe(frame)" :frame="frame" />
</template>
</div>
</template>
<script lang="ts">
import { defineComponent, unref, computed } from 'vue';
import FramePage from '@jeesite/core/layouts/iframe/FramePage.vue';
import { useFrameKeepAlive } from './useFrameKeepAlive';
export default defineComponent({
name: 'FrameLayout',
components: { FramePage },
setup() {
const { getFramePages, hasRenderFrame, showIframe } = useFrameKeepAlive();
const showFrame = computed(() => unref(getFramePages).length > 0);
return { getFramePages, hasRenderFrame, showIframe, showFrame };
},
});
</script>