数据库的三层菜单存储数据:
如图所示:
parent_id为根节点,0代表最外层的菜单,也就是一级菜单,是后面子菜单的父节点(即除0是父节点以外,其余都是子节点)
menu_sort为排列顺序,menu_type代表类型,1为下拉菜单,2为页面
第二层菜单从parent_id为1开始,parent_id 为1对应第一个parent_id为0的最外层菜单,parent_id 为2对应第二个parent_id为0的最外层菜单…
以此类推,到第二层的parent_id全部对应第一次的parent_id时,第三层菜单(页面)就开始了,第三层菜单(页面)的parent_id对应第二层的parent_id,如图可知,parent_id为9的对应parent_id为1,页面必须有menu_url,也就是跳转路径,在项目中jsp须与其相同
在项目中调用查询,查询数据库中的所有符合条件的菜单
再把得到的菜单数据通过request传到HTML
遍历循环输出的HTML格式:
最后得出结果:
总结得出:先拥有菜单数据,然后需要查询数据库中的菜单数据,再遍历菜单数据,根据父节点遍历查询子节点,再从子节点中遍历查询子节点,直到所有子节点下没有子节点