menuType
字段區分<template>
<div>
<template v-for="(menu, index) in menus">
<!-- 類型爲菜單時,使用 el-submenu -->
<el-submenu v-if="menu.menuType == 1" :index="menu.menuId" :key="menu.menuId">
<template slot="title">
<i :class="menu.icon"></i>
<span slot="title">{{menu.menuName}}</span>
</template>
<!-- 只有菜單有下級,因此放在這個位置 -->
<menu-list :menus="menu.menuList"></menu-list>
</el-submenu>
<!-- 類型爲功能時,使用 el-menu-item -->
<el-menu-item v-if="menu.menuType == 2" :index="((index+1).toString()+ '-' + (index+1).toString())" :key="menu.menuId"> <!--一級菜單功能-->
<router-link :to="menu.functionUrl" @click.native="flushCom(menu.functionUrl)">{{menu.menuName}}</router-link>
</el-menu-item>
</template>
</div>
</template>
複製代碼
export default {
props: ['menus'],
name: 'MenuList',
}
複製代碼
注意:使用自身組件時,不須要引入,只須要把 name 屬性定義好便可vue
<el-menu>
<menu-list :menus="menuList"></menu-list>
</el-menu>
複製代碼
export default {
components: {
menuList: () => import("./components/menuList.vue")
},
data() {
return {
menuList: []
}
}
}
複製代碼