index.vue 822 字节
Newer Older
陈文彬 已提交
1
<template>
V
vben 已提交
2
  <div v-if="showFrame">
V
vben 已提交
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">
V
vben 已提交
13 14
import { defineComponent, unref, computed } from 'vue'
import FramePage from '/@/views/sys/iframe/index.vue'
V
vben 已提交
15

V
vben 已提交
16
import { useFrameKeepAlive } from './useFrameKeepAlive'
V
vben 已提交
17

V
vben 已提交
18 19 20 21 22
export default defineComponent({
  name: 'FrameLayout',
  components: { FramePage },
  setup() {
    const { getFramePages, hasRenderFrame, showIframe } = useFrameKeepAlive()
V
vben 已提交
23

V
vben 已提交
24
    const showFrame = computed(() => unref(getFramePages).length > 0)
V
vben 已提交
25

V
vben 已提交
26 27 28
    return { getFramePages, hasRenderFrame, showIframe, showFrame }
  },
})
陈文彬 已提交
29
</script>