成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Ruby on Rails導航菜單自動生成的方法

開發 開發工具
本文介紹了Ruby on Rails導航菜單自動生成的方法。實現方法是,通過深度優先遍歷來生成菜單,在便利過程中構建菜單的html編碼,主要是使用了一個@htmlmenu的string來拼接生成的html代碼,最終顯示在頁面中。

最近在做的一個ROR的web項目中遇到如下問題:

產品可以按類分類導航瀏覽,主要可以分為A,B,C三類,三類之下還有其他分類,同時,基類和其下的分類都可以由用戶擴展。從橫向上,主類可以由用戶擴展,縱向上,用戶也可以擴展。

類別信息存儲與categories表中:

id:integer         主鍵

name:string        類別名稱

parentid:integer   類別的父類

要求:

生成導航菜單,并且可以含有子類的菜單可以通過點擊展開或關閉,并且可以按類別導航產品。

實現Ruby on Rails導航菜單:

通過深度優先遍歷來生成菜單,在便利過程中構建菜單的html編碼,主要是使用了一個@htmlmenu的string來拼接生成的html代碼,最終顯示在頁面中。

Ruby on Rails導航菜單代碼:

  1. def index  
  2.     @htmlmenu="" 
  3.     @htmlmenu+= "< ul>" 
  4.     @root = Category.find(:all,:conditions=>['parentid=0'])  
  5.     @root.each { |item|  
  6.     if Category.find_by_parentid(item.id)  
  7.     @htmlmenu+= "< li>< a href='#ChildMenu#{item.id}' onclick=\"DoMenu('ChildMenu#{item.id}')\">" 
  8.     else 
  9.       @htmlmenu+= "< li>< a href='/categories/#{item.id}'>" 
  10.     end 
  11.     @htmlmenu+= item.name  
  12.     @htmlmenu+= "< /a>" 
  13.     buildmenu item  
  14.     @htmlmenu+= "< /li>" 
  15.     }  
  16.     @htmlmenu+= "< /ul>" 
  17.   end 
  18.   private  
  19.   def buildmenu category  
  20.     @children = Category.find_all_by_parentid(category.id)  
  21.     if @children.size!=0  
  22.       @htmlmenu+= "< ul id='ChildMenu#{category.id}' class='collapsed'>" 
  23.       @children.each { |item|  
  24.         if Category.find_all_by_parentid(item.id).size!=0  
  25.           @htmlmenu+= "< li>< a href='#ChildMenu#{item.id}' onclick=\"DoMenu('ChildMenu#{item.id}')\">" 
  26.         else 
  27.                 @htmlmenu+= "< li>< a href='/categories/#{item.id}'>" 
  28.         end 
  29.  
  30.         @htmlmenu+= item.name  
  31.         @htmlmenu+= "< /a>" 
  32.         buildmenu item  
  33.         @htmlmenu+= "< /li>" 
  34.         }  
  35.       @htmlmenu+= "< /ul>" 
  36.  
  37.     end 
  38.       
  39.   end 

遍歷方法為private的buildmenu方法。

說明:parentid=0是為了找到所有的基類,他們的parentid默認為0;

在代碼中需要加入css和js:

  1. < script type="text/javascript"> 
  2.  
  3.  
  4. function DoMenu(emid){  
  5.     var obj = document.getElementById(emid);  
  6.     obj.className = (obj.className.toLowerCase() == "expanded"?"collapsed":"expanded");  
  7.    
  8. }  
  9. --> 
  10. < /script> 
  11. < style> 
  12.  ul.collapsed {  
  13.  display: none;  
  14. }  
  15. < /style> 

有關Ruby on Rails導航菜單的補充:

1.這是一個雛形,關于性能問題有以下幾點:

1.1  代碼可以優化,有些比較判斷沒有必要,懶得去掉了:)

1.2  如果類別數據增多,如果擔心過多的數據庫訪問,可以把這些寫到程序初始化里去,不過缺點是新增的類別需要重啟服務器后可以生效

2.我覺得這個拿去做文件系統遍歷很好,而且可以直接生成html頁面~

【編輯推薦】

  1. Ruby on Rails安裝及MySQL數據庫配置指南
  2. Ruby on Rails開發的五點建議
  3. Ruby的瓶頸 以及PHP何以成為Web之王
  4. 淺談Ruby和JRuby的學習
  5. Web開發誰更高效 Java對決Ruby on Rails
責任編輯:yangsai 來源: JavaEye博客
相關推薦

2009-12-17 09:31:02

Ruby on Rai

2009-08-27 10:21:22

Ruby on Rai

2009-12-16 17:24:26

Ruby on Rai

2009-12-17 11:14:50

Ruby on Rai

2009-08-06 09:13:36

Ruby on Rai

2010-09-25 14:39:29

Bruce Tate

2009-09-29 17:04:29

2009-12-17 15:02:32

Ruby on Rai

2009-12-14 15:30:43

安裝Ruby on R

2015-10-14 17:27:18

性能

2009-12-17 14:29:50

Ruby on Rai

2015-10-10 11:00:05

RubyRails性能

2009-12-16 16:37:59

Ruby on Rai

2009-06-17 10:08:32

Ruby on Rai安裝Ruby

2009-07-20 09:12:54

Ruby on Rai

2009-12-16 15:41:10

Ruby on Rai

2009-12-16 17:37:31

Ruby on Rai

2009-12-17 17:37:42

Ruby on Rai

2009-12-16 15:23:33

Ruby on rai

2013-03-28 12:42:02

RubyRails
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩精品无码一区二区三区 | 亚洲精品日韩一区二区电影 | 日本黄色免费大片 | 欧美成人精品一区二区男人看 | 日本高清视频在线播放 | 久久国产精品精品 | 激情五月激情综合网 | 国产99精品 | 91久久久www播放日本观看 | av在线一区二区三区 | 国产成人免费视频 | 久久精品久久久久久 | 日韩精品久久久久久 | 欧美色综合网 | 久久久精品视 | 欧美精品在欧美一区二区 | 美国一级毛片a | 91视频在线| 激情五月婷婷综合 | 久久久久久久电影 | 久久久久久亚洲精品 | 四虎永久免费黄色影片 | 成人午夜精品 | 欧美日韩在线观看视频网站 | 国产精品1区2区 | 久久精品国产精品青草 | 91精品国产91久久久 | 一区二区三区免费观看 | 午夜影院在线观看版 | 久热免费在线 | 全部免费毛片在线播放网站 | 欧美成人激情 | 亚洲视频一区在线观看 | 久久五月婷 | 中文字幕乱码视频32 | 日本黄色片免费在线观看 | 国产a级毛片| 亚洲精品1| 香蕉一区 | 国产精品久久久久久模特 | 美女一级毛片 |