Struts-Menu动态菜单

       最近需要使用 StrutsMenu 显示动态菜单,菜单的相关信息保存在数据库表中,通过 StrutsMenu 读取数据库中的数据,进行动态显示。下面的操作可以显示一个基本的动态菜单,但心里总觉得没底,似乎实现的方法很笨的样子,希望大家能提供更好的实现方法.
      实现过程如下,在Oracle数据库中建立了表 menu-item ,存贮了菜单的相关信息。表结构如下:
     

表中用来定义菜单的数据如下: 表中字段 PARENT_NAME 用来定义菜单的父级菜单, NAME 字段为菜单的名字, title 为菜单显示的标题。

     在JSP页面中,通过如下代码显示动态菜单,显示菜单所需要的包同《初涉StrutsMenu》中lib中所包含的包,在《初涉StrutsMenu》中中已经提供了下载。

  1. <%@ page contentType="text/html; charset=UTF-8" %>  
  2. <%@ taglib uri="/WEB-INF/tld/struts-menu.tld" prefix="menu" %>  
  3. <%@ taglib uri="/WEB-INF/tld/struts-menu-el.tld" prefix="menu-el" %>  
  4. <%@ taglib uri="/WEB-INF/tld/c.tld" prefix="c" %>  
  5. <%@ taglib uri="/WEB-INF/tld/fmt.tld" prefix="fmt" %>  
  6. <%@ taglib uri="/WEB-INF/tld/sql.tld" prefix="sql" %>  
  7. <%@ page import="java.sql.*"%>  
  8. <%@ page import="java.util.*" %>  
  9. <%@ page import="bean.MyMenu" %>  
  10.   
  11.        
  12. <%@ page import="java.util.Map,   
  13.                  javax.servlet.jsp.jstl.sql.Result,   
  14.                  net.sf.navigator.menu.MenuComponent,   
  15.                  net.sf.navigator.menu.MenuRepository"%>  
  16.   
  17. <head>  
  18. <title>menu testtitle>  
  19.       
  20.     <link rel="stylesheet" type="text/css" media="screen" href="styles/global.css" />  
  21.     <link rel="stylesheet" type="text/css" media="screen" href="styles/menuExpandable.css"/>  
  22.     <script type="text/javascript" src="scripts/menuExpandable.js">script>  
  23.     <link rel="stylesheet" type="text/css" media="all"    href="styles/xtree.css"/>  
  24.     <script type="text/javascript" src="scripts/xtree.js">script>        
  25.     <script type="text/javascript">  
  26.         /* Function for showing and hiding elements that use 'display:none' to hide */   
  27.         function toggleDisplay(targetId) {   
  28.             if (document.getElementById) {   
  29.                 target = document.getElementById(targetId);   
  30.                 if (target.style.display == "none"){   
  31.                     target.style.display = "";   
  32.                 } else {   
  33.                     target.style.display = "none";   
  34.                 }   
  35.             }   
  36.         }   
  37.     script>  
  38.     head>  
  39. <body>  
  40.   
  41.     <%   
  42.         ArrayList<Map> ary=new ArrayList<Map>();   
  43.         Connection con=null;   
  44.         try{   
  45.             Class.forName("oracle.jdbc.driver.OracleDriver");   
  46.             con=DriverManager.getConnection   
  47.   
  48. ("jdbc:oracle:thin:@127.0.0.1:1521:system","scott","tiger");   
  49.         }catch(Exception e){   
  50.             System.out.println("Error in index:"+e.getMessage());   
  51.         }   
  52.         Statement state=con.createStatement();   
  53.         ResultSet rs=state.executeQuery("SELECT id,parent_name,name,title,location FROM menu_item");   
  54.            
  55.         while(rs.next()){   
  56.             Map temp=new HashMap();   
  57.             temp.put("id",rs.getString("id"));   
  58.             temp.put("name",rs.getString("name"));   
  59.             temp.put("parent_name",rs.getString("parent_name"));   
  60.             temp.put("title",rs.getString("title"));   
  61.             temp.put("location",rs.getString("location"));   
  62.             ary.add(temp);   
  63.         }   
  64.         request.setAttribute("menus",ary);   
  65.            
  66.         MenuRepository repository = new MenuRepository();   
  67.         MenuRepository defaultRepository = (MenuRepository)   
  68.                 application.getAttribute(MenuRepository.MENU_REPOSITORY_KEY);   
  69.         repository.setDisplayers(defaultRepository.getDisplayers());   
  70.         ArrayList result=(ArrayList)request.getAttribute("menus");   
  71.         Iterator iterator=result.iterator();   
  72.         int id=0;   
  73.         System.out.println("out while");   
  74.         while(iterator.hasNext()){   
  75.             MenuComponent mc = new MenuComponent();   
  76.             Map row=(Map)result.get(id);   
  77.             String name=(String)row.get("name");   
  78.             mc.setName(name);   
  79.             String parent=(String)row.get("parent_name");   
  80.              if (parent != null) {   
  81.                     MenuComponent parentMenu = repository.getMenu(parent);   
  82.                     if (parentMenu == null) {   
  83.                         System.out.println("parentMenu '" + parent + "' doesn't exist!");   
  84.                         parentMenu = new MenuComponent();   
  85.                         parentMenu.setName(parent);   
  86.                         repository.addMenu(parentMenu);   
  87.                     }   
  88.   
  89.                     mc.setParent(parentMenu);   
  90.                 }   
  91.                
  92.               String title = (String) row.get("title");   
  93.               mc.setTitle(title);   
  94.               String location = (String) row.get("location");   
  95.               mc.setLocation(location);   
  96.               repository.addMenu(mc);   
  97.               iterator.next();   
  98.               id++;   
  99.         }   
  100.         pageContext.setAttribute("repository", repository);   
  101.     %>  
  102.        
  103.        
  104.     <div id="content">  
  105.         <script type="text/javascript" src="./scripts/coolmenus3.js">script>  
  106.         <script type="text/javascript" src="./scripts/coolmenu-config.js">script>    
  107.     
  108.         <menu:useMenuDisplayer name="CoolMenu" config="/templates/coolmenus.html"  
  109.            repository="repository"  bundle="org.apache.struts.action.MESSAGE">  
  110.           <c:forEach var="menu" items="${repository.topMenus}">  
  111.             <menu-el:displayMenu name="${menu.name}"/>  
  112.           c:forEach>  
  113.         menu:useMenuDisplayer>  
  114.     div>  
  115. body>  
  116. html>  

显示效果如下:希望大家能提供更好的实现方式.

<v:shapetype id="_x0000_t75" path="m@4@5l@4@11@9@11@9@5xe" o:preferrelative="t" filled="f" stroked="f" coordsize="21600,21600" o:spt="75"> <v:stroke joinstyle="miter"></v:stroke><v:formulas><v:f eqn="if lineDrawn pixelLineWidth 0"></v:f><v:f eqn="sum @0 1 0"></v:f><v:f eqn="sum 0 0 @1"></v:f><v:f eqn="prod @2 1 2"></v:f><v:f eqn="prod @3 21600 pixelWidth"></v:f><v:f eqn="prod @3 21600 pixelHeight"></v:f><v:f eqn="sum @0 0 1"></v:f><v:f eqn="prod @6 1 2"></v:f><v:f eqn="prod @7 21600 pixelWidth"></v:f><v:f eqn="sum @8 21600 0"></v:f><v:f eqn="prod @7 21600 pixelHeight"></v:f><v:f eqn="sum @10 21600 0"></v:f></v:formulas><v:path o:extrusionok="f" o:connecttype="rect" gradientshapeok="t"></v:path><o:lock aspectratio="t" v:ext="edit"></o:lock></v:shapetype>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值