<template> <router-view> </router-view> <el-popover :width="407" placement="left" v-if="description"> <template #reference> <div class="menuIcons"> <img src="../src/assets/images/setting/show_menu.png" style="margin-bottom: -3px" /> </div> </template> <template #default> <div class="menu-description flex flex-v"> <div class="description-title flex flex-align-center">文档描述</div> <div class="description-content" v-html="description"></div> </div> </template> </el-popover> </template> <script setup> import { getToken } from '@/utils/auth'; import { listMenu } from '@/api/menu'; import useSettingsStore from '@/store/modules/settings'; import { handleThemeStyle } from '@/utils/theme'; import { useRouter } from 'vue-router'; const router = useRouter(); const description = ref(''); watch( () => router.currentRoute.value.path, (newValue, oldValue) => { if (!!!router.currentRoute.value.meta.title) return; getMenuList(router.currentRoute.value.meta.title); }, { immediate: true } ); function getMenuList(menuName) { if (getToken()) { listMenu({ menuName: menuName }).then(res => { if (res.data.length) { description.value = res.data[0].description; } else { description.value = ''; } }); } } onMounted(() => { nextTick(() => { handleThemeStyle(useSettingsStore().theme); }); }); </script> <style lang="scss" scoped> .menuIcons { position: absolute; right: 60px; bottom: 50px; z-index: 999; box-shadow: 0px 0px 3px #000000; border-radius: 50%; } :deep(.el-popper) { padding: 0 !important; } .menu-description { width: 407px; border-radius: 2px 2px 0px 0px; .description-title { width: 400px; height: 50px; margin: -12px; background: #1981ff; border-radius: 2px 2px 0px 0px; font-size: 18px; font-family: Source Han Sans CN; font-weight: 500; color: #ffffff; padding-left: 19px; } .description-content { width: 400px; margin-left: -12px; margin-right: -12px; padding: 24px 12px 12px 12px; font-size: 14px; font-family: Source Han Sans CN; font-weight: 500; color: #666666; } } </style>