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

Ruby on Rails導(dǎo)航菜單自動生成的方法

開發(fā) 開發(fā)工具
本文介紹了Ruby on Rails導(dǎo)航菜單自動生成的方法。實(shí)現(xiàn)方法是,通過深度優(yōu)先遍歷來生成菜單,在便利過程中構(gòu)建菜單的html編碼,主要是使用了一個@htmlmenu的string來拼接生成的html代碼,最終顯示在頁面中。

最近在做的一個ROR的web項(xiàng)目中遇到如下問題:

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

類別信息存儲與categories表中:

id:integer         主鍵

name:string        類別名稱

parentid:integer   類別的父類

要求:

生成導(dǎo)航菜單,并且可以含有子類的菜單可以通過點(diǎn)擊展開或關(guān)閉,并且可以按類別導(dǎo)航產(chǎn)品。

實(shí)現(xiàn)Ruby on Rails導(dǎo)航菜單:

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

Ruby on Rails導(dǎo)航菜單代碼:

  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默認(rèn)為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> 

有關(guān)Ruby on Rails導(dǎo)航菜單的補(bǔ)充:

1.這是一個雛形,關(guān)于性能問題有以下幾點(diǎn):

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

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

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

【編輯推薦】

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

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
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 国产在线不卡视频 | 日本亚洲一区 | 免费观看一级毛片视频 | 成人精品在线观看 | 亚洲成人福利在线观看 | 国产欧美一区二区三区免费 | 久久国产精品免费一区二区三区 | 污视频在线免费观看 | 国产一区二区视频在线观看 | 欧美一区二区精品 | 国产一区精品 | 一级毛片免费看 | 久久久久国产精品免费免费搜索 | 一区二区三区免费观看 | 羞羞的视频免费观看 | 国产精品国产a级 | 综合久久久久 | 你懂的在线视频播放 | 欧美日韩一区二区在线 | 一区二区三区欧美在线 | 欧美一级毛片免费观看 | 亚洲日日 | 日韩一区二区久久 | 羞羞视频在线观看网站 | 伊人春色成人网 | 国产精品视频久久 | 国产激情小视频 | 精品国产伦一区二区三区观看方式 | av男人的天堂在线 | 中文字幕亚洲欧美日韩在线不卡 | 久热免费 | 免费视频99 | 久久精品二区亚洲w码 | 久久国产精品一区 | 亚洲视频中文字幕 | 国产欧美一区二区三区免费 | 久久美女网 | 91精品国产综合久久久久久漫画 | 日本精品999 | 草久久久 | 免费国产一区二区 |