优化页签全屏显示

This commit is contained in:
RuoYi
2026-03-26 00:52:25 +08:00
parent 4a0446dce0
commit 8b724ab409

View File

@@ -43,7 +43,10 @@
<el-dropdown-item command="closeLeft" :disabled="isFirstView()"><back style="width: 1em; height: 1em;" />关闭左侧</el-dropdown-item> <el-dropdown-item command="closeLeft" :disabled="isFirstView()"><back style="width: 1em; height: 1em;" />关闭左侧</el-dropdown-item>
<el-dropdown-item command="closeRight" :disabled="isLastView()"><right style="width: 1em; height: 1em;" />关闭右侧</el-dropdown-item> <el-dropdown-item command="closeRight" :disabled="isLastView()"><right style="width: 1em; height: 1em;" />关闭右侧</el-dropdown-item>
<el-dropdown-item command="closeAll"><circle-close style="width: 1em; height: 1em;" />全部关闭</el-dropdown-item> <el-dropdown-item command="closeAll"><circle-close style="width: 1em; height: 1em;" />全部关闭</el-dropdown-item>
<el-dropdown-item command="fullscreen" divided><full-screen style="width: 1em; height: 1em;" />全屏显示</el-dropdown-item> <el-dropdown-item command="fullscreen" divided>
<template v-if="!isFullscreen"><full-screen style="width: 1em; height: 1em;" />全屏显示</template>
<template v-else><close style="width: 1em; height: 1em;" />退出全屏</template>
</el-dropdown-item>
</el-dropdown-menu> </el-dropdown-menu>
</template> </template>
</el-dropdown> </el-dropdown>
@@ -81,6 +84,7 @@ const scrollPaneRef = ref(null)
const canScrollLeft = ref(false) const canScrollLeft = ref(false)
const canScrollRight = ref(false) const canScrollRight = ref(false)
const isFullscreen = ref(false) const isFullscreen = ref(false)
const hiddenElements = ref([])
const { proxy } = getCurrentInstance() const { proxy } = getCurrentInstance()
const route = useRoute() const route = useRoute()
@@ -117,14 +121,21 @@ onMounted(() => {
initTags() initTags()
addTags() addTags()
window.addEventListener('resize', updateArrowState) window.addEventListener('resize', updateArrowState)
document.addEventListener('fullscreenchange', onFullscreenChange) window.addEventListener('keydown', handleKeyDown)
}) })
onBeforeUnmount(() => { onBeforeUnmount(() => {
window.removeEventListener('resize', updateArrowState) window.removeEventListener('resize', updateArrowState)
document.removeEventListener('fullscreenchange', onFullscreenChange) window.removeEventListener('keydown', handleKeyDown)
}) })
function handleKeyDown(event) {
// 当按下Esc键且处于全屏状态时退出全屏
if (event.key === 'Escape' && isFullscreen.value) {
toggleFullscreen()
}
}
function isActive(r) { function isActive(r) {
return r.path === route.path return r.path === route.path
} }
@@ -235,22 +246,34 @@ function updateArrowState() {
} }
function toggleFullscreen() { function toggleFullscreen() {
if (!document.fullscreenElement) { const mainContainer = document.querySelector('.main-container')
const appMain = document.querySelector('.app-main') const navbar = document.querySelector('.navbar')
if (appMain) { const sidebar = document.querySelector('.sidebar-container')
appMain.requestFullscreen() if (!mainContainer) return
}
} else {
document.exitFullscreen()
}
}
function onFullscreenChange() { if (!isFullscreen.value) {
isFullscreen.value = !!document.fullscreenElement mainContainer.classList.add('fullscreen-mode')
const appMain = document.querySelector('.app-main') document.body.style.overflow = 'hidden'
if (appMain && !settingsStore.isDark) { const elementsToHide = [{ el: navbar, originalDisplay: navbar?.style.display || '' }, { el: sidebar, originalDisplay: sidebar?.style.display || '' }]
appMain.style.backgroundColor = document.fullscreenElement ? '#fff' : '' elementsToHide.forEach(item => {
appMain.style.overflowY = document.fullscreenElement ? 'auto' : '' if (item.el && item.el.style.display !== 'none') {
item.originalDisplay = item.el.style.display
item.el.style.display = 'none'
hiddenElements.value.push(item)
}
})
isFullscreen.value = true
} else {
mainContainer.classList.remove('fullscreen-mode')
document.body.style.overflow = ''
hiddenElements.value.forEach(item => {
if (item.el) {
item.el.style.display = item.originalDisplay
}
})
hiddenElements.value = []
document.querySelector('.tags-action-btn').blur()
isFullscreen.value = false
} }
} }
@@ -517,4 +540,41 @@ function handleScroll() {
} }
} }
} }
</style>
/* 页签全屏模式样式 */
.main-container.fullscreen-mode {
position: fixed;
top: 0;
left: 0;
width: 100vw;
height: 100vh;
overflow: hidden;
}
.main-container.fullscreen-mode .fixed-header {
display: block !important;
position: fixed;
top: 0;
left: 0;
right: 0;
width: 100% !important;
z-index: 1000;
}
.main-container.fullscreen-mode .fixed-header .navbar {
display: none !important;
}
.main-container.fullscreen-mode .app-main {
position: fixed;
top: 34px;
left: 0;
right: 0;
bottom: 0;
margin: 0 !important;
padding: 0 !important;
height: calc(100vh - 34px) !important;
min-height: calc(100vh - 34px) !important;
overflow: auto;
}
</style>