From b421d2fedd1dfbe400363b89a6281c0759508651 Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期四, 19 九月 2024 10:08:20 +0800 Subject: [PATCH] 最新版本 --- admin/src/components/common/Menu.vue | 115 +++++++++++++++++++++++---------------------------------- 1 files changed, 47 insertions(+), 68 deletions(-) diff --git a/admin/src/components/common/Menu.vue b/admin/src/components/common/Menu.vue index 96422f6..0b0df39 100644 --- a/admin/src/components/common/Menu.vue +++ b/admin/src/components/common/Menu.vue @@ -1,22 +1,23 @@ <template> - <div class="menu" :class="{collapse: menuData.collapse}"> - <div class="logo"> - <div><img src="@/assets/logo.png"></div> - <h1 :class="{hidden: menuData.collapse}">{{title}}</h1> - </div> + <div class="menu" :class="{ collapse: menuData.collapse }"> <scrollbar> -<!-- :default-openeds="defaultOpeneds"--> <el-menu ref="menu" - :unique-opened="true" :default-active="activeIndex" - text-color="#fff" - active-text-color="#fff" + text-color="#333333" + active-text-color="#207FF7" :collapse="menuData.collapse" + :default-openeds="defaultOpeneds" :collapse-transition="false" + unique-opened @select="handleSelect" > - <MenuItems v-for="menu in menuData.list" :key="menu.index" :menu="menu" :is-root-menu="true"/> + <MenuItems + v-for="menu in menuData.list" + :key="menu.index" + :menu="menu" + :is-root-menu="true" + /> </el-menu> </scrollbar> </div> @@ -28,52 +29,58 @@ import Scrollbar from './Scrollbar' export default { name: 'Menu', - data() { - return { - title: process.env.VUE_APP_TITLE - } - }, components: { Scrollbar, MenuItems }, computed: { ...mapState(['menuData']), // 閫変腑鐨勮彍鍗昳ndex - activeIndex () { + activeIndex() { let path = this.$route.path if (path.endsWith('/')) { path = path.substring(0, path.length - 1) } - const menuConfig = this.__getMenuConfig(path, 'url', this.menuData.list) + const menuConfig = this.__getMenuConfig(path, 'index', this.menuData.list) if (menuConfig == null) { return null + } else { + this.$store.commit('pushtags', menuConfig) } + // console.log(menuConfig.index); return menuConfig.index }, // 榛樿灞曞紑鐨勮彍鍗昳ndex - defaultOpeneds () { - return this.menuData.list.map(menu => menu.index) + defaultOpeneds() { + // return this.menuData.list.map(menu => menu.index) + + return [this.menuData.list[0].index] } }, methods: { // 澶勭悊鑿滃崟閫変腑 - handleSelect (menuIndex) { + handleSelect(menuIndex) { const menuConfig = this.__getMenuConfig(menuIndex, 'index', this.menuData.list) // 鎵句笉鍒伴〉闈� try { require('@/views' + menuConfig.url) } catch (e) { this.$tip.error('鏈壘鍒伴〉闈㈡枃浠禓/views' + menuConfig.url + '.vue锛岃妫�鏌ヨ彍鍗曡矾寰勬槸鍚︽纭�') + return } // 鐐瑰嚮褰撳墠鑿滃崟涓嶅仛澶勭悊 - if (menuConfig.url === this.$route.path) { + if (menuConfig.url === this.$route.path && (menuConfig.params == null || menuConfig.params == undefined || menuConfig.params == '' || menuConfig.params === this.$route.query.param)) { return } if (menuConfig.url == null || menuConfig.url.trim().length === 0) { return } - this.$router.push(menuConfig.url) + if (menuConfig.params != null && menuConfig.params != '') { + this.$router.push({ path: menuConfig.url, query: { index: menuConfig.index, param: menuConfig.params } }) + } else { + this.$router.push(menuConfig.url) + } + this.$store.commit('pushtags', menuConfig) }, // 鑾峰彇鑿滃崟閰嶇疆 - __getMenuConfig (value, key, menus) { + __getMenuConfig(value, key, menus) { for (const menu of menus) { if (menu[key] === value) { return menu @@ -97,37 +104,6 @@ height: 100%; display: flex; flex-direction: column; - // LOGO - .logo { - height: 60px; - flex-shrink: 0; - line-height: 60px; - overflow: hidden; - display: flex; - background: $primary-color - 20; - padding: 0 16px; - & > div { - width: 32px; - flex-shrink: 0; - margin-right: 12px; - img { - width: 100%; - flex-shrink: 0; - vertical-align: middle; - position: relative; - top: -2px; - } - } - h1 { - font-size: 16px; - font-weight: 500; - transition: opacity ease .3s; - overflow: hidden; - &.hidden { - opacity: 0; - } - } - } } </style> <style lang="scss"> @@ -136,46 +112,49 @@ .el-menu { border-right: 0 !important; user-select: none; - background: $primary-color !important; + background: #fff !important; .el-menu-item { - background: $primary-color; + background: #fff; + height: 48px; + line-height: 48px; // 閫変腑鐘舵�� &.is-active { - background: $primary-color - 40 !important; + background: #eff5fe !important; } // 鎮诞 &:hover { - background-color: $primary-color - 12; + background-color: #eff5fe; } &:focus { - background: $primary-color; + background: #eff5fe; } } // 瀛愯彍鍗� .el-submenu { - .el-submenu__title{ - background-color: $primary-color; + .el-submenu__title { + background-color: #fff; } &.is-active { - .el-submenu__title{ - background-color: $primary-color - 20; + .el-submenu__title { + background-color: #fff; } - .el-menu .el-menu-item{ - background-color: $primary-color - 20; + .el-menu .el-menu-item { + background-color: #fff; // 鎮诞 &:hover { - background-color: $primary-color - 30; + background-color: #eff5fe; } } } // 鑿滃崟涓婁笅绠ご .el-submenu__title i { - color: #f7f7f7; + color: #979797; + font-size: 14px; } } // 鑿滃崟鍥炬爣 i:not(.el-submenu__icon-arrow) { - color: #f7f7f7 !important; + color: #333333 !important; position: relative; top: -1px; // 鑷畾涔夊浘鏍� -- Gitblit v1.9.3