隨筆-208  評論-469  文章-30  trackbacks-0


          動畫教程第十四集

           

          使用struts-menu制作樹型菜單實例


          下載:http://oksonic.kc100.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, title, location) VALUES(3,'DatabaseMenu','JavaBlogs','JavaBlogs','http://javablogs.com');

          INSERT INTO menu_item (id, name, title, location) VALUES (4,'StandaloneMenu','Standalone Menu','http://raibledesigns.com');

           

           

          創建 Hibernate 框架,配置數據庫連接,關于數據庫連接的配置就不做介紹了,如果不知道如何配置的話請參考以前發布的錄像!

          記得點擊 Copy JDBC Driver and add to classpath 鏈接

           

          打開 MyEclipse Database Explorer 視圖,創建 menu_item 的映射文件

           

          修改 FindAction.java 文件,內容如下:

          import java.util.List;

          import javax.servlet.ServletContext;

          import javax.servlet.http.HttpServletRequest;

          import javax.servlet.http.HttpServletResponse;

          import javax.servlet.http.HttpSession;

          import net.sf.navigator.menu.MenuComponent;

          import net.sf.navigator.menu.MenuRepository;

          import org.apache.struts.action.Action;

          import org.apache.struts.action.ActionForm;

          import org.apache.struts.action.ActionForward;

          import org.apache.struts.action.ActionMapping;

          import org.hibernate.Query;

          import org.hibernate.Session;

          import org.hibernate.Transaction;

          import com.Hibernate.MenuItem;

          import com.Hibernate.SessionFactory;

           

          public class FindAction extends Action {

           

              public ActionForward execute(

                  ActionMapping mapping,

                  ActionForm form,

                  HttpServletRequest request,

                  HttpServletResponse response) {

                  //創建連接

                             Session session=SessionFactory.currentSession();

                  //創建事務

                             Transaction tx=session.beginTransaction();

                  //創建對話

                             Query query=session.createQuery("FROM MenuItem m order by id");

                  List list=query.list();

                  //事務提交

                             tx.commit();

                  if(list.size()<0)

                      return mapping.getInputForward();

                  MenuRepository repository = new MenuRepository();

                  HttpSession httpsession=(HttpSession)request.getSession();

                  ServletContext application=(ServletContext)httpsession.getServletContext();

                  MenuRepository defaultRepository = (MenuRepository)application.getAttribute(MenuRepository.MENU_REPOSITORY_KEY);

                  repository.setDisplayers(defaultRepository.getDisplayers());

                  for (int i=0; i < list.size(); i++) {

                      MenuComponent mc = new MenuComponent();

                      MenuItem mi=(MenuItem) list.get(i);

                      String name = mi.getName();

                      mc.setName(name);

                      String parent = (String) mi.getParentName();

                      System.out.println(name + ", parent is: " + parent);

                      if (parent != null) {

                          MenuComponent parentMenu = repository.getMenu(parent);

                          if (parentMenu == null) {

                              System.out.println("parentMenu '" + parent + "' doesn't exist!");

                              // create a temporary parentMenu

                              parentMenu = new MenuComponent();

                              parentMenu.setName(parent);

                              repository.addMenu(parentMenu);

                          }

                          mc.setParent(parentMenu);

                      }

                      String title = (String)mi.getTitle();

                      mc.setTitle(title);

                      String location = (String) mi.getLocation();

                      mc.setLocation(location);

                      repository.addMenu(mc);

                  }

                  request.setAttribute("repository", repository);

                  return mapping.findForward("okGo");

              }

          }

           

          以上代碼是使用了hibernate操作數據,得到一個數據集,并將數據集添加到MenuRepository中

          然后在jsp頁面中使用以下代碼顯示樹型菜單

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

                      <menu:displayMenu name="DatabaseMenu"/>

                      <menu:displayMenu name="StandaloneMenu"/>

                  </menu:useMenuDisplayer>

           

          menu-config.xml 文件中的內容已經被精減了,如果要使用XML文件來配置菜單的話,請查看struts-menu的示例

          代碼完成,現在進行測試!

           

          好了,顯示正常,這集就講到此了,下集再見!!!

          posted on 2006-01-17 19:56 EricWong 閱讀(180) 評論(0)  編輯  收藏 所屬分類: Java
          <2006年1月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          2930311234

          留言簿(44)

          隨筆分類(120)

          相冊

          收藏夾(15)

          links

          搜索

          •  

          最新評論

          閱讀排行榜

          51La
          主站蜘蛛池模板: 太原市| 临江市| 武安市| 金湖县| 和林格尔县| 冷水江市| 平泉县| 汶川县| 赤峰市| 海盐县| 宣武区| 海伦市| 德安县| 芒康县| 辉南县| 黄骅市| 曲阳县| 淮南市| 徐州市| 绥化市| 祁门县| 海门市| 安国市| 两当县| 开远市| 沾化县| 油尖旺区| 萨嘎县| 高青县| 洛隆县| 嘉祥县| 柯坪县| 红原县| 马边| 顺昌县| 德格县| 饶阳县| 砀山县| 万年县| 红安县| 金沙县|