| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169 | <template>  <!-- 左下:菜单栏 -->  <div class="menu-box-1">    <div class="menu-box-2">      <!--        菜单:          unique-opened = 是否只有菜单打开          default-active = 正在高亮的菜单id          collapse = 是否折叠          参考文档:https://element.eleme.cn/#/zh-CN/component/menu      -->      <el-menu          class="el-menu-style-1"          :default-active="$root.activeMenuId"          :collapse="!$root.isOpen"          @select="selectMenu"      >        <div v-for="(menu, index) in $root.menuList" v-if="!menu.show" :key="index">          <!-- 1 如果是子菜单 -->          <el-menu-item v-if="!menu.parent && menu.isShow !== false && $root.showList.indexOf(menu.id) > -1"                        :index="menu.id + '' ">            <span class="menu-i"><i :class="menu.icon" :title="menu.name"></i></span>            <span class="menu-name">{{ menu.name }}</span>          </el-menu-item>          <!-- 1 如果是父菜单 -->          <el-submenu v-if="menu.parent && menu.isShow !== false && $root.showList.indexOf(menu.id) > -1"                      :index="menu.id + '' ">            <template slot="title">              <span class="menu-i"><i :class="menu.icon" :title="menu.name"></i></span>              <span class="menu-name">{{ menu.name }}</span>            </template>            <!-- 遍历其子项 -->            <div v-for="(menu2, index) in menu.childList" :key="index">              <!-- 2 如果是子菜单 -->              <el-menu-item v-if="!menu2.parent && menu2.isShow !== false && $root.showList.indexOf(menu2.id) > -1"                            :index="menu2.id + '' ">                <span class="menu-i"><i :class="menu2.icon" :title="menu2.name"></i></span>                <span class="menu-name">{{ menu2.name }}</span>              </el-menu-item>              <!-- 2 如果是父菜单 -->              <el-submenu v-if="menu2.parent && menu2.isShow !== false && $root.showList.indexOf(menu2.id) > -1"                          :index="menu2.id + '' ">                <template slot="title">                  <span class="menu-i"><i :class="menu2.icon" :title="menu2.name"></i></span>                  <span class="menu-name">{{ menu2.name }}</span>                </template>                <!-- 遍历其子项 -->                <div v-for="(menu3, index) in menu2.childList" :key="index">                  <!-- 3 如果是子菜单 -->                  <el-menu-item v-if="!menu3.parent && menu3.isShow !== false && $root.showList.indexOf(menu3.id) > -1"                                :index="menu3.id + '' ">                    <span class="menu-i"><i :class="menu3.icon" :title="menu3.name"></i></span>                    <span class="menu-name">{{ menu3.name }}</span>                  </el-menu-item>                  <!-- 3 如果是父菜单 -->                  <el-submenu v-if="menu3.parent && menu3.isShow !== false && $root.showList.indexOf(menu3.id) > -1"                              :index="menu3.id + '' ">                    <template slot="title">                      <span class="menu-i"><i :class="menu3.icon" :title="menu3.name"></i></span>                      <span class="menu-name">{{ menu3.name }}</span>                    </template>                    <!-- 4 -->                    <div v-for="(menu4, index) in menu3.childList" :key="index">                      <el-menu-item v-if="menu4.isShow !== false && $root.showList.indexOf(menu4.id) > -1"                                    :index="menu4.id + '' ">                        <span class="menu-i"><i :class="menu4.icon" :title="menu4.name"></i></span>                        <span class="menu-name">{{ menu4.name }}</span>                      </el-menu-item>                    </div>                  </el-submenu>                </div>              </el-submenu>            </div>          </el-submenu>        </div>      </el-menu>      <!-- tab被拖拽时的遮罩(左拖拽:关闭) -->      <div class="shade-fox" v-if="$root.isDrag"           @dragover="$event.preventDefault();"           @drop="$event.preventDefault(); $event.stopPropagation(); $root.$refs['com-right-menu'].rightTab = $root.dragTab; $root.$refs['com-right-menu'].right_close();">        <span style="font-size: 16px;">关闭</span>      </div>    </div>  </div></template><script>module.exports = {  data() {    return {}  },  methods: {    // 点击子菜单时触发的回调    // 参数:index=点击菜单index标识(不是下标,是菜单id),    // 		indexArray=所有已经打开的菜单id数组,形如:['1', '1-1', '1-1-1']    selectMenu: function (index, indexArray) {      this.$root.showMenuById(index);    },  },  created() {  }}</script><style scoped>/* 1 2 配合,把滚动条隐藏 */.menu-box-1 {  width: calc(var(--nav-left-width) + 20px);  height: 100%;  overflow-y: auto;}.menu-box-2 {  width: calc(var(--nav-left-width) + 1px);  padding-bottom: 200px;}.menu-box-1 i[class^=el-icon-] {  font-size: 16px;}.menu-box-2 .menu-i {  display: inline-block;  vertical-align: top;  width: 29px;}/* 动画速度加快 */.menu-box-1, .menu-box-2 * {  transition: all 0.2s;}/* 隐藏右边框 */.el-menu {  border: 0px;}/* 一级菜单,高度45px */.el-menu-item,.el-submenu__title {  height: 45px !important;  line-height: 45px !important;}/* 二级以下菜单,高度40px */.el-submenu .el-menu-item,.el-submenu .el-submenu .el-submenu__title {  height: 40px !important;  line-height: 40px !important;}/* 二级菜单 左边距 */.el-submenu .el-menu-item,.el-submenu .el-submenu .el-submenu__title {  padding-left: 2.5em !important;}/* 三级菜单 左边距 */.el-submenu .el-submenu .el-menu-item,.el-submenu .el-submenu .el-submenu .el-submenu__title {  padding-left: 3.6em !important;}/* 四级菜单 左边距 */.el-submenu .el-submenu .el-submenu .el-menu-item {  padding-left: 4.7em !important;}</style>
 |