| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- <template>
- <el-aside class="layout-aside" :class="setCollapseWidth" v-if="clientWidth > 1000">
- <Logo v-if="setShowLogo && menuList.length" />
- <el-scrollbar class="flex-auto" ref="layoutAsideRef">
- <Vertical :menuList="menuList" :class="setCollapseWidth" />
- </el-scrollbar>
- </el-aside>
- <el-drawer :visible.sync="getThemeConfig.isCollapse" :with-header="false" direction="ltr" size="180px" v-else>
- <el-aside class="layout-aside w100 h100">
- <Logo v-if="setShowLogo && menuList.length" />
- <el-scrollbar class="flex-auto" ref="layoutAsideRef">
- <Vertical :menuList="menuList" />
- </el-scrollbar>
- </el-aside>
- </el-drawer>
- </template>
- <script>
- import Vertical from '@/layout/navMenu/vertical.vue';
- import Logo from '@/layout/logo/index.vue';
- export default {
- name: 'layoutAside',
- components: { Vertical, Logo },
- data() {
- return {
- menuList: [],
- clientWidth: '',
- };
- },
- computed: {
- // 设置左侧菜单的具体宽度
- setCollapseWidth() {
- let { layout, isCollapse } = this.$store.state.themeConfig.themeConfig;
- let asideBrColor = '';
- layout === 'classic' || layout === 'columns' ? (asideBrColor = 'layout-el-aside-br-color') : '';
- if (layout === 'columns') {
- // 分栏布局,菜单收起时宽度给 1px
- if (isCollapse) {
- return ['layout-aside-width1', asideBrColor];
- } else {
- return ['layout-aside-width-default', asideBrColor];
- }
- } else {
- // 其它布局给 64px
- if (isCollapse) {
- return ['layout-aside-width64', asideBrColor];
- } else {
- return ['layout-aside-width-default', asideBrColor];
- }
- }
- },
- // 设置 logo 是否显示
- setShowLogo() {
- let { layout, isShowLogo } = this.$store.state.themeConfig.themeConfig;
- return (isShowLogo && layout === 'defaults') || (isShowLogo && layout === 'columns');
- },
- // 获取布局配置信息
- getThemeConfig() {
- return this.$store.state.themeConfig.themeConfig;
- },
- },
- created() {
- this.initMenuFixed(document.body.clientWidth);
- this.setFilterRoutes();
- this.bus.$on('setSendColumnsChildren', (res) => {
- console.log('收到了', res);
- this.menuList = res || [];
- });
- this.bus.$on('layoutMobileResize', (res) => {
- this.initMenuFixed(res.clientWidth);
- });
- // 菜单滚动条监听
- this.bus.$on('updateElScrollBar', () => {
- setTimeout(() => {
- this.$refs.layoutAsideRef.update();
- }, 300);
- });
- },
- methods: {
- // 设置/过滤路由(非静态路由/是否显示在菜单中)
- setFilterRoutes() {
- if (this.$store.state.themeConfig.themeConfig.layout === 'columns') return false;
- this.menuList = this.filterRoutesFun(this.$store.state.routesList.routesList);
- },
- // 设置/过滤路由 递归函数
- filterRoutesFun(arr) {
- return arr
- .filter((item) => item.path)
- .map((item) => {
- item = Object.assign({}, item);
- if (item.children) item.children = this.filterRoutesFun(item.children);
- return item;
- });
- },
- // 设置菜单导航是否固定(移动端)
- initMenuFixed(clientWidth) {
- this.clientWidth = clientWidth;
- },
- },
- // 页面销毁时
- destroyed() {
- // 取消菜单滚动条监听
- this.bus.$off('updateElScrollBar', () => {});
- },
- };
- </script>
|