后端

main-sidebar.vue 3.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <template>
  2. <aside class="site-sidebar" :class="'site-sidebar--' + sidebarLayoutSkin">
  3. <div class="site-sidebar__inner">
  4. <el-menu
  5. :default-active="menuActiveName || 'home'"
  6. :collapse="sidebarFold"
  7. :collapseTransition="false"
  8. class="site-sidebar__menu">
  9. <el-menu-item index="home" @click="$router.push({ name: 'home' })">
  10. <icon-svg name="shouye" class="site-sidebar__menu-icon"></icon-svg>
  11. <span slot="title">首页</span>
  12. </el-menu-item>
  13. <el-submenu index="demo">
  14. <template slot="title">
  15. <icon-svg name="shoucang" class="site-sidebar__menu-icon"></icon-svg>
  16. <span>demo</span>
  17. </template>
  18. <el-menu-item index="demo-echarts" @click="$router.push({ name: 'demo-echarts' })">
  19. <icon-svg name="tubiao" class="site-sidebar__menu-icon"></icon-svg>
  20. <span slot="title">echarts</span>
  21. </el-menu-item>
  22. <el-menu-item index="demo-ueditor" @click="$router.push({ name: 'demo-ueditor' })">
  23. <icon-svg name="editor" class="site-sidebar__menu-icon"></icon-svg>
  24. <span slot="title">ueditor</span>
  25. </el-menu-item>
  26. </el-submenu>
  27. <sub-menu
  28. v-for="menu in menuList"
  29. :key="menu.menuId"
  30. :menu="menu"
  31. :dynamicMenuRoutes="dynamicMenuRoutes">
  32. </sub-menu>
  33. </el-menu>
  34. </div>
  35. </aside>
  36. </template>
  37. <script>
  38. import SubMenu from './main-sidebar-sub-menu'
  39. import { isURL } from '@/utils/validate'
  40. export default {
  41. data () {
  42. return {
  43. dynamicMenuRoutes: []
  44. }
  45. },
  46. components: {
  47. SubMenu
  48. },
  49. computed: {
  50. sidebarLayoutSkin: {
  51. get () { return this.$store.state.common.sidebarLayoutSkin }
  52. },
  53. sidebarFold: {
  54. get () { return this.$store.state.common.sidebarFold }
  55. },
  56. menuList: {
  57. get () { return this.$store.state.common.menuList },
  58. set (val) { this.$store.commit('common/updateMenuList', val) }
  59. },
  60. menuActiveName: {
  61. get () { return this.$store.state.common.menuActiveName },
  62. set (val) { this.$store.commit('common/updateMenuActiveName', val) }
  63. },
  64. mainTabs: {
  65. get () { return this.$store.state.common.mainTabs },
  66. set (val) { this.$store.commit('common/updateMainTabs', val) }
  67. },
  68. mainTabsActiveName: {
  69. get () { return this.$store.state.common.mainTabsActiveName },
  70. set (val) { this.$store.commit('common/updateMainTabsActiveName', val) }
  71. }
  72. },
  73. watch: {
  74. $route: 'routeHandle'
  75. },
  76. created () {
  77. this.menuList = JSON.parse(sessionStorage.getItem('menuList') || '[]')
  78. this.dynamicMenuRoutes = JSON.parse(sessionStorage.getItem('dynamicMenuRoutes') || '[]')
  79. this.routeHandle(this.$route)
  80. },
  81. methods: {
  82. // 路由操作
  83. routeHandle (route) {
  84. if (route.meta.isTab) {
  85. // tab选中, 不存在先添加
  86. var tab = this.mainTabs.filter(item => item.name === route.name)[0]
  87. if (!tab) {
  88. if (route.meta.isDynamic) {
  89. route = this.dynamicMenuRoutes.filter(item => item.name === route.name)[0]
  90. if (!route) {
  91. return console.error('未能找到可用标签页!')
  92. }
  93. }
  94. tab = {
  95. menuId: route.meta.menuId || route.name,
  96. name: route.name,
  97. title: route.meta.title,
  98. type: isURL(route.meta.iframeUrl) ? 'iframe' : 'module',
  99. iframeUrl: route.meta.iframeUrl || '',
  100. params: route.params,
  101. query: route.query
  102. }
  103. this.mainTabs = this.mainTabs.concat(tab)
  104. }
  105. this.menuActiveName = tab.menuId + ''
  106. this.mainTabsActiveName = tab.name
  107. }
  108. }
  109. }
  110. }
  111. </script>