速动画教程第十四集

 

使用struts-menu制作树型菜单实例

下载:http://sonic.peakle.net/download/sonic014.rar
 

制作人:速

 

新建j2ee工程,工程名称为:struts-menu

Context root URL: /menu

选中Add JSTL libraries to WEB-INF/lib forlder? JSTL版本(随意)

 

以下所有的文件可以从源代码中拷贝

拷贝文件中的以下内容到工程的webroot目录中

imagesscriptsstylestemplates 四个文件夹

 

拷贝以下文件到 /WEB-INF/ 目录

struts-menu.tld

struts-menu-el.tld

menu-config.xml

 

拷贝以下文件到 /WEB-INF/lib/ 目录

struts-menu-2.3.jar

velocity-1.4.jar

velocity-tools-view-1.0.jar

 

拷贝以下文件到 /src/ 目录

globalMacros.vm

 

拷贝以下文件到 /WEB-INF/lib/ 目录,此文件是在使用j2ee1.4版本创建工程时才需要

commons-lang-2.0.jar         此文件将在录像包中提供

 

刷新工程

 

创建Struts框架

 

按下Ctrl + N ,使用向导新增 struts 插件

 

Plugin class: net.sf.navigator.menu.MenuPlugIn

点击 add 按钮,在对话框中填入以下内容

Property:menuConfig

   Value:/WEB-INF/menu-config.xml

 

 

按下Ctrl + N ,使用向导新增 Action

Use case:find

其它使用默认值

 

在WebRoot目录中新建两个jsp文件,index.jsp ok.jsp

 

创建一个 Forward

name:okGo

Path:/ok.jsp

 

修改 index.jsp 文件,内容如下:

<html>

  <head>

    <title>ok</title>

  </head>

  <body>

    <a href="find.do">Find</a>

  </body>

</html>

 

修改 ok.jsp 文件,内容如下:

<%@ page contentType="text/html;charset=UTF-8" language="java"%>

<%@ taglib uri="/WEB-INF/struts-menu.tld" prefix="menu" %>

<%@ taglib uri="/WEB-INF/struts-menu-el.tld" prefix="menu-el" %>

<%@ taglib uri="/WEB-INF/c.tld" prefix="c" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"

    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">

<head>

    <title>Dynamic, Database-driven Menu</title>

    <link rel="stylesheet" type="text/css" media="all"

        href="<c:url value="/styles/menuExpandable.css"/>" />

    <script type="text/javascript"

        src="<c:url value="/scripts/menuExpandable.js"/>"></script>

    <link rel="stylesheet" type="text/css" media="all"

        href="<c:url value="/styles/xtree.css"/>" />

    <script type="text/javascript"

        src="<c:url value="/scripts/xtree.js"/>"></script>

    <link rel="stylesheet" type="text/css" media="all"

        href="<c:url value="/styles/global.css"/>" />

    <script type="text/javascript">

        /* Function for showing and hiding elements that use 'display:none' to hide */

        function toggleDisplay(targetId) {

            if (document.getElementById) {

                target = document.getElementById(targetId);

                if (target.style.display == "none"){

                    target.style.display = "";

                } else {

                    target.style.display = "none";

                }

            }

        }

    </script>

</head>

<body>

    <div class="dynamicMenu">

        <menu:useMenuDisplayer name="ListMenu" repository="repository">

            <menu:displayMenu name="DatabaseMenu"/>

            <menu:displayMenu name="StandaloneMenu"/>

        </menu:useMenuDisplayer>

    </div>

    <div class="dynamicMenu tree">

    <script type="text/javascript">

        <menu:useMenuDisplayer name="Velocity" config="/templates/xtree.html"

            repository="repository">

          <c:forEach var="menu" items="${repository.topMenus}">

            <menu-el:displayMenu name="${menu.name}"/>

          </c:forEach>

        </menu:useMenuDisplayer>

    </script>

    </div>

</body>

</html>

 

创建数据库表

CREATE TABLE `menu_item` (

  `id` bigint(20) NOT NULL default '0',

  `parent_name` varchar(30) default NULL,

  `name` varchar(30) default NULL,

  `title` varchar(30) default NULL,

  `description` varchar(50) default NULL,

  `location` varchar(255) default NULL,

  `target` varchar(10) default NULL,

  `onclick` varchar(100) default NULL,

  `onmouseover` varchar(100) default NULL,

  `onmouseout` varchar(100) default NULL,

  `image` varchar(50) default NULL,

  `altImage` varchar(30) default NULL,

  `tooltip` varchar(100) default NULL,

  `roles` varchar(100) default NULL,

  `page` varchar(255) default NULL,

  `width` varchar(5) default NULL,

  `height` varchar(5) default NULL,

  `forward` varchar(50) default NULL,

  `action` varchar(50) default NULL,

  PRIMARY KEY  (`id`)

);

INSERT INTO menu_item (id, name, title) VALUES (1,'DatabaseMenu','Database Menu');

INSERT INTO menu_item (id, parent_name, name, title, location) VALUES (2,'DatabaseMenu','Yahoo','Yahoo Mail','http://mail.yahoo.com');

INSERT INTO menu_item (id, parent_name, name,