gaoluyang
8 天以前 3e955639e7d984db92766918cb93e17355c8ea0e
src/layout/components/AppMain.vue
@@ -2,9 +2,12 @@
  <section class="app-main">
    <router-view v-slot="{ Component, route }">
      <transition name="fade-transform" mode="out-in">
        <keep-alive :include="tagsViewStore.cachedViews">
          <component v-if="!route.meta.link" :is="Component" :key="route.path"/>
        </keep-alive>
        <div v-if="!route.meta.link" class="route-view-wrapper">
          <keep-alive :include="tagsViewStore.cachedViews">
            <component :is="Component" :key="route.path"/>
          </keep-alive>
        </div>
        <div v-else class="route-view-wrapper"></div>
      </transition>
    </router-view>
    <iframe-toggle />
@@ -15,7 +18,22 @@
import iframeToggle from "./IframeToggle/index"
import useTagsViewStore from '@/store/modules/tagsView'
const route = useRoute()
const tagsViewStore = useTagsViewStore()
onMounted(() => {
  addIframe()
})
watchEffect(() => {
  addIframe()
})
function addIframe() {
  if (route.meta.link) {
    useTagsViewStore().addIframeView(route)
  }
}
</script>
<style lang="scss" scoped>
@@ -25,6 +43,12 @@
  width: 100%;
  position: relative;
  overflow: hidden;
  background: #F5F7FB;
}
.route-view-wrapper {
  width: 100%;
  height: 100%;
}
.fixed-header + .app-main {