gaoluyang
8 天以前 3e955639e7d984db92766918cb93e17355c8ea0e
src/layout/components/AppMain.vue
@@ -2,21 +2,38 @@
  <section class="app-main">
    <router-view v-slot="{ Component, route }">
      <transition name="fade-transform" mode="out-in">
        <keep-alive :include="cachedViews">
          <component :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 />
  </section>
</template>
<script setup>
let store = useStore()
import iframeToggle from "./IframeToggle/index"
import useTagsViewStore from '@/store/modules/tagsView'
const route = useRoute()
store.dispatch('tagsView/addCachedView', route)
const cachedViews = computed(() => {
    return store.state.tagsView.cachedViews
const tagsViewStore = useTagsViewStore()
onMounted(() => {
  addIframe()
})
watchEffect(() => {
  addIframe()
})
function addIframe() {
  if (route.meta.link) {
    useTagsViewStore().addIframeView(route)
  }
}
</script>
<style lang="scss" scoped>
@@ -26,6 +43,12 @@
  width: 100%;
  position: relative;
  overflow: hidden;
  background: #F5F7FB;
}
.route-view-wrapper {
  width: 100%;
  height: 100%;
}
.fixed-header + .app-main {
@@ -48,7 +71,22 @@
// fix css style bug in open el-dialog
.el-popup-parent--hidden {
  .fixed-header {
    padding-right: 17px;
    padding-right: 6px;
  }
}
</style>
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
::-webkit-scrollbar-track {
  background-color: #f1f1f1;
}
::-webkit-scrollbar-thumb {
  background-color: #c0c0c0;
  border-radius: 3px;
}
</style>