spring
20 小时以前 a57e03f7cb03c1ba5f2f2b4c5d7a06b0ed1d0ecb
src/layout/components/AppMain.vue
@@ -2,23 +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>
import useTagsViewStore from '@/store/modules/tagsview'
import iframeToggle from "./IframeToggle/index"
import useTagsViewStore from '@/store/modules/tagsView'
const tagsViewStore = useTagsViewStore()
const route = useRoute()
tagsViewStore.addCachedView(route)
const cachedViews = computed(() => {
    return tagsViewStore.cachedViews
const tagsViewStore = useTagsViewStore()
onMounted(() => {
  addIframe()
})
watchEffect(() => {
  addIframe()
})
function addIframe() {
  if (route.meta.link) {
    useTagsViewStore().addIframeView(route)
  }
}
</script>
<style lang="scss" scoped>
@@ -28,10 +43,17 @@
  width: 100%;
  position: relative;
  overflow: hidden;
  background: transparent;
}
.route-view-wrapper {
  width: 100%;
  height: 100%;
  padding: 120px 16px 24px 0;
}
.fixed-header + .app-main {
  padding-top: 50px;
  padding-top: 0;
}
.hasTagsView {
@@ -41,7 +63,7 @@
  }
  .fixed-header + .app-main {
    padding-top: 84px;
    padding-top: 0;
  }
}
</style>
@@ -50,7 +72,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: rgba(218, 225, 220, 0.8);
}
::-webkit-scrollbar-thumb {
  background-color: #b2bdb5;
  border-radius: 3px;
}
</style>