index.vue 1.8 KB
Newer Older
Mr.奇淼('s avatar
Mr.奇淼( 已提交
1
<template>
2
  <div>
3 4
    <el-scrollbar style="height:calc(100vh)">
      <el-menu
5
        class="el-menu-vertical"
6 7 8 9 10 11 12 13 14 15 16 17
        :collapse="isCollapse"
        :collapse-transition="true"
        :default-active="active"
        @select="selectMenuItem"
        active-text-color="#fff"
        text-color="rgb(191, 203, 217)"
        unique-opened
      >
        <template v-for="item in asyncRouters[0].children">
          <aside-component :key="item.name" :routerInfo="item" v-if="!item.hidden" />
        </template>
      </el-menu>
18
    </el-scrollbar>
19
  </div>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
20 21 22
</template>

<script>
Mr.奇淼('s avatar
Mr.奇淼( 已提交
23
import { mapGetters,mapMutations } from 'vuex'
Mr.奇淼('s avatar
Mr.奇淼( 已提交
24 25 26 27 28 29
import AsideComponent from '@/view/layout/aside/asideComponent'
export default {
  name: 'Aside',
  data() {
    return {
      active: '',
30
      isCollapse: false
Mr.奇淼('s avatar
Mr.奇淼( 已提交
31 32 33
    }
  },
  methods: {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
34
    ...mapMutations("history",["addHistory"]),
Mr.奇淼('s avatar
Mr.奇淼( 已提交
35
    selectMenuItem(index) {
36 37
      if (index === this.$route.name) return
      this.$router.push({ name: index })
Mr.奇淼('s avatar
Mr.奇淼( 已提交
38 39
    }
  },
40 41
  computed: {
    ...mapGetters('router', ['asyncRouters'])
J
导航  
jinlan.du 已提交
42

Mr.奇淼('s avatar
Mr.奇淼( 已提交
43 44 45 46 47
  },
  components: {
    AsideComponent
  },
  created() {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
48
    this.active = this.$route.name
J
导航  
jinlan.du 已提交
49 50 51 52
    let screenWidth = document.body.clientWidth
     if(screenWidth<1000){
       this.isCollapse = !this.isCollapse
      }
53 54 55
    this.$bus.on('totalCollapse', () => {
      this.isCollapse = !this.isCollapse
    })
J
导航  
jinlan.du 已提交
56 57 58 59
     this.$bus.on('collapse', (item) => {
      this.isCollapse = item
    })

60
  },
Mr.奇淼('s avatar
Mr.奇淼( 已提交
61 62 63 64 65
  watch:{
    $route(){
      this.active = this.$route.name
    }
  },
66 67
  beforeDestroy() {
    this.$bus.off('totalCollapse')
J
导航  
jinlan.du 已提交
68
    this.$bus.off('collapse')
Mr.奇淼('s avatar
Mr.奇淼( 已提交
69 70 71
  }
}
</script>
72 73

<style lang="scss">
74 75
.el-scrollbar {
  .el-scrollbar__view {
Mr.奇淼('s avatar
Mr.奇淼( 已提交
76 77 78
    height: 100%;
  }
}
79 80 81 82 83 84 85 86 87
.menu-info {
  .menu-contorl {
    line-height: 52px;
    font-size: 20px;
    display: table-cell;
    vertical-align: middle;
  }
}
</style>