好久沒寫博客了緣由就是懶,html
剛下班今天寫了個基於element導航菜單實現多層菜單(能夠無限多層)vue
組件核心思想就是組件遞歸(這個有時候面試會問到)面試
能夠看看這篇我寫的簡單文章《vue組件遞歸》ide
而後就判斷children有沒有內容,沒內容就是選擇項嘛,內容就是父菜單spa
只提供最基礎實現功能各類回調能夠參考element文檔去改,我只寫了主體.net
element導航菜單官方文檔:https://element.eleme.cn/2.0/#/zh-CN/component/menucode
效果圖:component
// ====== 組件: ==================htm
<template> <div> <template v-for="(item,index) in list"> <!-- 標題 --> <template v-if="item.children.length"> <el-submenu :key="index" :index="item.index"> <template :index="item.index" slot="title"> <i :class="item.icon"></i> <span>{{item.name}}</span> </template> <el-menu-item-group> <sideBar :list="item.children"></sideBar> </el-menu-item-group> </el-submenu> </template> <!-- 選項 --> <template v-else> <el-menu-item :key="index" :index="item.index"> <i :class="item.icon"></i> <span>{{item.name}}</span> </el-menu-item> </template> </template> </div> </template> <script> export default { name: "sideBar", props: { list: Array } }; </script> <style></style>
// ====== 調用: ==================blog
<!-- html調用 --> <el-menu> <SideBar :list="sideBarData"></SideBar> </el-menu> // 這個是數據格式 sideBarData: [ { name: "菜單1", index: "menu1", icon: "el-icon-menu", children: [ { name: "菜單1-1", index: "menu1-1", icon: "el-icon-menu", children: [ { name: "菜單1-1-1", index: "menu1-1-1", icon: "el-icon-menu", children: [] }, { name: "菜單1-1-2", index: "menu1-1-2", icon: "el-icon-menu", children: [] } ] }, { name: "菜單1-2", index: "menu1-2", icon: "el-icon-menu", children: [] } ] }, { name: "菜單2", index: "menu2", icon: "el-icon-document-copy", children: [ { name: "數據集管理2", index: "dataset2", icon: "el-icon-document-copy", children: [] }, ] }, { name: "菜單2", index: "menu3", icon: "el-icon-folder", children: [] } ]
補個截圖可能會好看好理解些:
最後推薦個文章也是寫「element多層導航菜單」不過這位大佬寫的比我詳細多了,
我寫的只是初級版幫助理解而已,進階的話看這篇文章是很好的:https://blog.csdn.net/qq_31126175/article/details/88824380