速动画教程第十四集
使用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目录中
images、scripts、styles、templates 四个文件夹
拷贝以下文件到 /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,