aside.vue 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. <template>
  2. <el-aside class="layout-aside" :class="setCollapseWidth" v-if="clientWidth > 1000">
  3. <Logo v-if="setShowLogo && menuList.length && getThemeConfig.layout !== 'columns'" />
  4. <div v-if="menuList.length && !getThemeConfig.isCollapse && getThemeConfig.layout == 'columns'" class="cat-name">
  5. {{ catName }}
  6. </div>
  7. <el-scrollbar class="flex-auto" ref="layoutAsideRef">
  8. <Vertical :menuList="menuList" :class="setCollapseWidth" />
  9. </el-scrollbar>
  10. </el-aside>
  11. <el-drawer :visible.sync="getThemeConfig.isCollapse" :with-header="false" direction="ltr" size="180px" v-else>
  12. <el-aside class="layout-aside w100 h100">
  13. <Logo v-if="setShowLogo && menuList.length" />
  14. <el-scrollbar class="flex-auto" ref="layoutAsideRef">
  15. <Vertical :menuList="menuList" />
  16. </el-scrollbar>
  17. </el-aside>
  18. </el-drawer>
  19. </template>
  20. <script>
  21. import Vertical from '@/layout/navMenu/vertical.vue';
  22. import Logo from '@/layout/logo/index.vue';
  23. export default {
  24. name: 'layoutAside',
  25. components: { Vertical, Logo },
  26. data() {
  27. return {
  28. // menuList: [],
  29. clientWidth: '',
  30. catName: '',
  31. };
  32. },
  33. computed: {
  34. // 设置左侧菜单的具体宽度
  35. menuList() {
  36. this.$store.state.menus.childMenuList.length > 0
  37. ? (this.$store.state.themeConfig.themeConfig.isCollapse = false)
  38. : (this.$store.state.themeConfig.themeConfig.isCollapse = true);
  39. return this.$store.state.menus.childMenuList;
  40. },
  41. setCollapseWidth() {
  42. let { layout, isCollapse } = this.$store.state.themeConfig.themeConfig;
  43. let asideBrColor = '';
  44. layout === 'classic' || layout === 'columns' ? (asideBrColor = 'layout-el-aside-br-color') : '';
  45. if (layout === 'columns') {
  46. // 分栏布局,菜单收起时宽度给 1px
  47. if (isCollapse) {
  48. return ['layout-aside-width1', asideBrColor];
  49. } else {
  50. return ['layout-aside-width-default', asideBrColor];
  51. }
  52. } else {
  53. // 其它布局给 64px
  54. if (isCollapse) {
  55. return ['layout-aside-width64', asideBrColor];
  56. } else {
  57. return ['layout-aside-width-default', asideBrColor];
  58. }
  59. }
  60. },
  61. // 设置 logo 是否显示
  62. setShowLogo() {
  63. let { layout, isShowLogo } = this.$store.state.themeConfig.themeConfig;
  64. return (isShowLogo && layout === 'defaults') || (isShowLogo && layout === 'columns');
  65. },
  66. // 获取布局配置信息
  67. getThemeConfig() {
  68. return this.$store.state.themeConfig.themeConfig;
  69. },
  70. },
  71. created() {
  72. this.initMenuFixed(document.body.clientWidth);
  73. this.setFilterRoutes();
  74. // this.bus.$on('setSendColumnsChildren', (res) => {
  75. // this.menuList = res || [];
  76. // this.menuList.length > 0
  77. // ? (this.$store.state.themeConfig.themeConfig.isCollapse = false)
  78. // : (this.$store.state.themeConfig.themeConfig.isCollapse = true);
  79. // });
  80. this.bus.$on('layoutMobileResize', (res) => {
  81. this.initMenuFixed(res.clientWidth);
  82. });
  83. this.bus.$on('oneCatName', (name) => {
  84. this.catName = name;
  85. });
  86. // 菜单滚动条监听
  87. this.bus.$on('updateElScrollBar', () => {
  88. setTimeout(() => {
  89. this.$refs.layoutAsideRef.update();
  90. }, 300);
  91. });
  92. if (this.$store.state.themeConfig.themeConfig.layout !== 'columns') {
  93. this.bus.$on('routesListChange', () => {
  94. this.setFilterRoutes();
  95. });
  96. }
  97. },
  98. beforeDestroy() {
  99. this.bus.$off('routesListChange');
  100. },
  101. methods: {
  102. // 设置/过滤路由(非静态路由/是否显示在菜单中)
  103. setFilterRoutes() {
  104. if (this.$store.state.themeConfig.themeConfig.layout === 'columns') return false;
  105. this.$store.commit('menus/childMenuList', this.filterRoutesFun(this.$store.state.routesList.routesList));
  106. // this.menuList = this.filterRoutesFun(this.$store.state.routesList.routesList);
  107. },
  108. // 设置/过滤路由 递归函数
  109. filterRoutesFun(arr) {
  110. return arr
  111. .filter((item) => item.path)
  112. .map((item) => {
  113. item = Object.assign({}, item);
  114. if (item.children) item.children = this.filterRoutesFun(item.children);
  115. return item;
  116. });
  117. },
  118. // 设置菜单导航是否固定(移动端)
  119. initMenuFixed(clientWidth) {
  120. this.clientWidth = clientWidth;
  121. },
  122. },
  123. // 页面销毁时
  124. destroyed() {
  125. // 取消菜单滚动条监听
  126. this.bus.$off('updateElScrollBar', () => {});
  127. },
  128. };
  129. </script>
  130. <style lang="scss" scoped>
  131. .cat-name {
  132. display: flex;
  133. align-items: center;
  134. justify-content: center;
  135. height: 50px;
  136. border-bottom: 1px solid var(--prev-border-color-lighter);
  137. font-weight: 500;
  138. font-size: 15px;
  139. }
  140. </style>