<template> <!-- 部分全屏页面 --> <app-main v-if="FullScreen" /> <div v-else :class="classObj" class="app-wrapper" :style="{ '--current-color': theme }"> <div v-if="device === 'mobile' && sidebar.opened" class="drawer-bg" @click="handleClickOutside" /> <sidebar v-if="!sidebar.hide" class="sidebar-container" /> <div :class="{ hasTagsView: needTagsView, sidebarHide: sidebar.hide }" class="main-container"> <div :class="{ 'fixed-header': fixedHeader }"> <navbar @setLayout="setLayout" /> <tags-view v-if="needTagsView" /> </div> <app-main /> <settings ref="settingRef" /> </div> </div> </template> <script setup> import { useWindowSize } from '@vueuse/core'; import Sidebar from './components/Sidebar/index.vue'; import { AppMain, Navbar, Settings, TagsView } from './components'; import defaultSettings from '@/settings'; import useAppStore from '@/store/modules/app'; import useSettingsStore from '@/store/modules/settings'; import { useRouter } from 'vue-router'; import { ref } from 'vue'; const router = useRouter(); const settingsStore = useSettingsStore(); const theme = computed(() => settingsStore.theme); const sideTheme = computed(() => settingsStore.sideTheme); const sidebar = computed(() => useAppStore().sidebar); const device = computed(() => useAppStore().device); const needTagsView = computed(() => settingsStore.tagsView); const fixedHeader = computed(() => settingsStore.fixedHeader); const classObj = computed(() => ({ hideSidebar: !sidebar.value.opened, openSidebar: sidebar.value.opened, withoutAnimation: sidebar.value.withoutAnimation, mobile: device.value === 'mobile', })); const { width, height } = useWindowSize(); const WIDTH = 992; // refer to Bootstrap's responsive design watchEffect(() => { if (device.value === 'mobile' && sidebar.value.opened) { useAppStore().closeSideBar({ withoutAnimation: false }); } if (width.value - 1 < WIDTH) { useAppStore().toggleDevice('mobile'); useAppStore().closeSideBar({ withoutAnimation: true }); } else { useAppStore().toggleDevice('desktop'); } }); function handleClickOutside() { useAppStore().closeSideBar({ withoutAnimation: false }); } const settingRef = ref(null); function setLayout() { settingRef.value.openSetting(); } const FullScreen = ref(false); watch( () => router.currentRoute.value.path, (newValue, oldValue) => { console.log('watch路由变化', newValue, router.currentRoute.value.query.type); if (router.currentRoute.value.query.type == 'FullScreen') { // 全屏页面 FullScreen.value = true; } else { // 非全屏页面 FullScreen.value = false; } }, { immediate: true } ); </script> <style lang="scss" scoped> @import '@/assets/styles/mixin.scss'; @import '@/assets/styles/variables.module.scss'; .app-wrapper { @include clearfix; position: relative; height: 100%; width: 100%; &.mobile.openSidebar { position: fixed; top: 0; } } .drawer-bg { background: #000; opacity: 0.3; width: 100%; top: 0; height: 100%; position: absolute; z-index: 999; } .fixed-header { position: fixed; top: 0; right: 0; z-index: 9; width: calc(100% - #{$base-sidebar-width}); transition: width 0.28s; } .hideSidebar .fixed-header { width: calc(100% - 54px); } .sidebarHide .fixed-header { width: 100%; } .mobile .fixed-header { width: 100%; } </style>