使用struts-menu制作樹型菜單實例錄像教程

          Posted on 2005-12-12 10:36 oksonic 閱讀(24574) 評論(43)  編輯  收藏 所屬分類: java

          速動畫教程第十四集

           

          使用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, 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的示例

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

           

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

           

          Feedback

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2005-12-13 22:03 by 吳淦
          我認為,你的實現方法很好。巧妙的采用了Hibernate+struts的優勢來設計。
          但是,我還是比較喜歡采用XML數據島+DOM+JS來設計樹。數據同樣可以取自數據庫。效率高很多。

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2005-12-15 02:10 by jack chen
          這里面的東西真的很好,真的感謝大哥如此熱心!!!

          有一小小建議:如果視頻能換個格式就更好了,比如加上聲音什么的.那樣可能給我們初學者有更好的幫忙.

          不管怎樣,再次感謝!!!希望繼續堅持下去.支持你!

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2005-12-17 15:35 by cyw --bjnkd

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2005-12-22 17:07 by lubaolin
          感謝呀!

          太好了!

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2005-12-27 11:17 by Jnaughty^_^
          感謝ING~~~~~~~~~~~~~~~~~~~~~~~~~~

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2005-12-28 17:06 by pillar
          內容不錯,版主辛苦了,永遠支持!!!

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2005-12-31 15:04 by sinoline
          非常感謝樓主,學到不少東西~頂~~

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-01-04 14:13 by slan
          強人,就是看著有點頭昏~~~~~~~~
          自我感覺用dtree加struts標簽或者自定義標簽要方便很多

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-01-04 15:30 by wuxufeng
          摟主,問一個問題,我想在frame中使用這個tree,但是我用mc.setTarget(target) 指定了他的目標,在數據庫中我也添加了相應的數據,為什么還是沒有轉到其它的頁面,很奇怪。更奇怪的是,我更新了數據庫中的節點,但是現實的tree還是最原始的那個結構,暈了。

          謝謝,能不能幫我看一下,我的email wuxufeng@ivo.com

          請盡快聯系我,搞不出來了,郁悶中

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-01-04 16:06 by wuxufeng
          那個tree結構不能更新我的問題我知道了。但是后面一個更奇怪的問題,你不是有兩種顯示格式嘛,我把后一種刪了,現在重新加回去就不能顯示了說
          暈倒了

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-01-04 16:20 by wuxufeng
          我的那個menu顯示頁面,就是從你這邊拷過來的,但是腳本錯誤,下面的那個tree顯示不出來,我早上還可以顯示呢

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-02-22 10:46 by 李決
          暈啊!老大,你真是有心了,以后我很常來您這,向您好好學習,希望你斷續下去.頂啊!!!

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-03-04 20:40 by chfeng
          很棒!!!!!!!!!!!

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-03-28 10:15 by WW
          找到親人了!!!!!!!!!

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-04-09 13:54 by xiaotong
          您好!看了這個程序覺得非常好,對我的幫助很大。
          可是我有一個問題,我想得到選中菜單的名字,怎么能得到,我急用,請您幫幫忙!
          謝謝 !!
          郵箱:xialingling_it@yahoo.com.cn

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-04-09 14:51 by dihin
          謝謝!
          真是一個好網站
          大家共同學習

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-04-18 16:14 by ping
          寫得很好.

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-04-28 08:48 by onlyzzw
          感謝樓主,順便問一下,rar.gstore的后綴文件用什么解,我用WINRAR解好像缺東西。

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-05-15 10:14 by camille
          strtus-menu顯示成功了,偶現在面臨的問題是,點擊菜單中的鏈接怎么在指定的框架中顯示的問題,改了數據庫里面的target=mainFrame. 在框架頁中也設定了該框架的name=mainFrame.不知道是不是還有哪個地方需要改,麻煩知道的GGMM告訴俺一下咯,共同學習,互相進步

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-05-22 08:55 by
          老大,強,繼續下去 ,謝謝你的幫助,我會不斷來這里。。。你是一個大牛人

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-06-06 15:03 by 湘江浪子
          我在數據庫里加入數據想顯示多級菜單,但是上面那個顯示方式能出來,下面這個顯示不出來,網頁還報錯,請問是什么原因呢!?

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-06-16 15:01 by 123456789
          這樣是不是只能顯示這種Listmenu樣式的菜單啊?
          我試了試別的,那個dropdown樣式的可以,別的好象都不行。
          如果用別的話,需要改哪啊???
          struts-menu的原理不懂,不知道怎么改。
          大家幫忙啊。

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-06-20 17:23 by 123456789
          這里面JSTL起的什么作用啊???

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-09-04 17:23 by ?
          Unable to find a value for "name" in object of class "java.lang.String" using operator "." (null)

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-09-28 19:26 by ebookdown
          辛苦辛苦!
          感謝中!

          # 出錯求助  回復  更多評論   

          2006-10-26 13:40 by ff_ff
          照您的操作,出錯:
          According to TLD or attribute directive in tag file, attribute items does not accept any expressions
          這是什么原因?
          我用的是struts1.2 jstl1.1
          有影響嗎?

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-10-31 17:07 by 逍遙不在
          大蝦,我和樓上的一樣的問題,請問和struts版本有關系嗎?
          謝謝~~~

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-12-15 11:59 by upforever
          爛嘴老師,果然弓雖

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-12-18 14:42 by LeVaN
          http://filmiki-najlepsze.lolas.pl ^^^ <a href="http://filmiki-najlepsze.lolas.pl">filmiki najlepsze</a> ^^^ [url]http://filmiki-najlepsze.lolas.pl[/url]

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2006-12-18 14:44 by LeVaN
          http://www.50-sex-video.beibi.info ^^^ http://www.60-luvun-pukeutuminen-mies-suomi.beibi.info ^^^ http://www.gratis-virgin-urinering.biseksuell.info ^^^ http://www.transseksuell-videoer.biseksuell.info ^^^ http://www.gratis-virgin-urinering.erotiska.info ^^^ http://www.transseksuell-videoer.erotiska.info ^^^ http://www.overnaturlig-mor-arte.fitta69.info ^^^ http://www.videor-transsexuell-naken.fitta69.info ^^^ http://www.kuk-naken-porr.fotsex.info ^^^ http://www.lesbisk-ful-porr.fotsex.info ^^^ http://www.webcam-naken-hardcore.isomuna.info ^^^ http://www.maksuton-xnxx-story.isomuna.info ^^^ http://www.rakastettava-tytsyt-striptease.laukeaminen.info ^^^ http://www.mami-sexsi-maksuton.laukeaminen.info ^^^ http://www.handjager-hetest-foto.rype.info ^^^ http://www.video-fett-suging.rype.info ^^^ http://www.sexy-officegirls-gallerier.sadsprut.info ^^^ http://www.galleri-strippe-lesbisk.sadsprut.info ^^^ http://www.porno-zpornstars-naida.tytsy.info ^^^ http://www.hockey-butik-lesbisk.tytsy.info ^^^ http://www.vids-ass-picture.18analsex.com ^^^ http://www.images-anal-pics.18analsex.com ^^^

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2007-02-14 15:20 by 某先知
          我配置好了,唯一的一個錯誤就是這個,請問這是什么問題?

          "FindAction.java": cannot access org.apache.commons.collections.map.LinkedMap; org.apache.commons.collections.map.LinkedMap at line 42, column 28

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2007-02-14 21:15 by 某先知
          我的當前項目的包里有commons-collections 這個包,原來還有一個2.1.1版的,我以為是兩個沖突,就把2.1.1的刪除了,現在還是不行...還是提示上面那個錯誤

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2007-02-15 15:24 by 某先知
          已經好了,struts1.2自帶的那個包不行,更新成最新版本(或者速動畫的版本)的就可以了

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2007-03-01 09:17 by tgh_alien
          我的項目里以前有commons-collections.jar這個包,用這個包會報這個錯誤.
          Error: compiler message file broken: key=complier.err.file org\apache\commons\collections\LinkedMap.class not found argument=null,null,null,null,null,null,null
          換成commons-collections-3.0.jar 就可以,但是只能是靜態顯示.要出數據庫中取得,會有問題,取得了個java.util.List,現在要把他轉成java.util.HashMap就會有問題 HashMap map=(HashMap)List.get(i) 錯誤是:
          java.lang.ClassCastException
          at entity.FindAction.execute(FindAction.java:58)
          請高手指教,敬謝!

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2007-04-20 17:48 by 軟件開發
          路過看看,多學習一下。

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2007-04-20 17:49 by 標志設計
          我喜歡你的博客!

          # 如果多幾棵樹,顯示的時候就出現以下問題:  回復  更多評論   

          2007-04-29 19:30 by mm
          如果多幾棵樹,顯示的時候就出現以下問題:
          最先顯示的樹,可以點擊那個+號,來顯示子目錄的內容,或點擊-號來隱藏子目錄的內容
          接著顯示的樹,點擊+或-號 都不能顯示或隱藏內容哦

          請問 請問是甚么問題呢

          ^_^

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2007-08-30 14:55 by Struts
          很好,不錯...

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2008-08-28 12:59 by 天亮
          為什么視頻下載不下來啊
          呵呵但是看代碼就夠了 謝謝 !!頂死你!!!

          # re: 使用struts-menu制作樹型菜單實例錄像教程  回復  更多評論   

          2008-09-08 09:55 by ss
          教程很好,就是視頻無法下載啊。謝謝,不知道代碼能不能運行

          # re: 使用struts-menu制作樹型菜單實例錄像教程[未登錄]  回復  更多評論   

          2008-12-18 19:19 by killer
          有病毒啊!暈死

          # re: 使用struts-menu制作樹型菜單實例錄像教程[未登錄]  回復  更多評論   

          2009-03-07 17:03 by aaa
          下載:http://sonic.peakle.net/download/sonic014.rar
          有木馬
          病毒真這么好玩嗎
          欺騙感情

          # re: 使用struts-menu制作樹型菜單實例錄像教程[未登錄]  回復  更多評論   

          2009-03-07 17:04 by aaa
          <h1>真沒有道德哈</h1>

          posts - 103, comments - 1104, trackbacks - 0, articles - 0

          Copyright © oksonic

          主站蜘蛛池模板: 攀枝花市| 大厂| 汝城县| 陵水| 会东县| 安泽县| 合阳县| 怀仁县| 长海县| 郎溪县| 阿合奇县| 枝江市| 井研县| 鹿邑县| 揭东县| 古田县| 新邵县| 齐齐哈尔市| 吴忠市| 资源县| 都昌县| 和静县| 方城县| 内丘县| 昭苏县| 龙游县| 喀什市| 上思县| 稷山县| 滨州市| 扎鲁特旗| 永福县| 长阳| 额济纳旗| 柯坪县| 岚皋县| 偏关县| 密山市| 泉州市| 牡丹江市| 濮阳市|