<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>