app-sider-menus.vue 1.6 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
<template>
  <div class="app-sider-menus">
      <template v-for="(item,index) in menus">
          <template v-if="item.items && Array.isArray(item.items) && item.items.length > 0">
              <el-submenu :index="item.id" :disabled="item.disabled">
                  <template slot='title'>
                      <img v-if="item.icon && !Object.is(item.icon, '')" :src="item.icon" class='app-menu-icon'/>
                      <i v-else-if="item.iconcls && !Object.is(item.iconcls, '')" :class="item.iconcls + ' app-menu-icon'"></i>
                      <template v-else></template>
                      <span>{{item.text}}</span>
                  </template>
                  <app-sider-menus :menus="item.items"></app-sider-menus>
              </el-submenu>
          </template>
          <template v-else>
              <el-menu-item :index="item.id" :disabled="item.disabled">
                  <img v-if="item.icon && !Object.is(item.icon, '')" :src="item.icon" class='app-menu-icon'/>
                  <i v-else-if="item.iconcls && !Object.is(item.iconcls, '')" :class="item.iconcls + ' app-menu-icon'"></i>
                  <template v-else></template>
                  <span slot='title'>{{item.text}}</span>
              </el-menu-item>
          </template>
      </template>
  </div>
</template>

<script lang='ts'>
import { Component, Vue, Prop, Model, Watch } from "vue-property-decorator";

@Component({})
export default class AppSiderMenus extends Vue {
  /**
   * 菜单数据
   *
   * @type {*}
   * @memberof AppSiderMenus
   */
  @Prop({ default: [] }) public menus!: any;
}
</script>

<style lang='less'>
@import "./app-sider-menus.less";
</style>