今天要做的是這么個東東,先上數(shù)據(jù)庫:
成都創(chuàng)新互聯(lián)專注于企業(yè)網(wǎng)絡(luò)營銷推廣、網(wǎng)站重做改版、臨潭網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、H5高端網(wǎng)站建設(shè)、成都做商城網(wǎng)站、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)公司、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為臨潭等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
是一個簡單的樹形結(jié)構(gòu),一個tree_id對應(yīng)一個parent_id,相當(dāng)于對應(yīng)一個父節(jié)點(diǎn),涉及到了自身的連接關(guān)系,其實還是挺復(fù)雜的數(shù)據(jù)庫設(shè)計,起碼當(dāng)初這個設(shè)計是怎么也木有看懂~
想要達(dá)到的想法是動態(tài)的在節(jié)點(diǎn)上增刪改,可以用鼠標(biāo)各種拖動換parent那種。不過現(xiàn)在的本事只能做成靜態(tài)的,現(xiàn)在的狀態(tài)是點(diǎn)擊某一節(jié)點(diǎn)的鏈接會顯示自己,父親,兒子,以及兄弟。
閑話少說,上代碼:
數(shù)據(jù)庫生成部分,很簡單的兩個屬性,注意id:false這句話,這是ruby 1.9之后才支持的特性,其實等同于 :id => false ,也就是說沒有在這個表中給規(guī)定rails默認(rèn)的id,那怎么辦?請看model部分~
class CreateTreeProviders < ActiveRecord::Migration def change create_table :tree_providers, id: false do |t| t.integer :tree_id t.integer :parent_id t.timestamps end end end
model部分在這里~注意這里面的has_many后面跟復(fù)數(shù),belongs_to后面放單數(shù)~~而且這兩者同樣的foreignkey都是parent_id,但是意思卻是不一樣的。前者是把自己作為主鍵,parent_id是別人的,后者相反,parent_id是自己的~這是我現(xiàn)在的理解。放了一個驗證函數(shù),保證在save之前執(zhí)行,確保自己不能是自己的parent。
class TreeProvider < ActiveRecord::Base attr_accessible :parent_id, :tree_id has_many :tree_providers , foreign_key: :parent_id belongs_to :tree_provider , foreign_key: :parent_id set_primary_key :tree_id before_save :judge_self def judge_self if parent_id == tree_id false end end end
Controller部分~~只更改了show這一個地方。注意@tree_provider
.tree_provider和
@tree_provider
.tree_providers的區(qū)別,其實這樣表示很沒有區(qū)分啦,所以一個現(xiàn)在解決不了的問題來了,
如何才能實現(xiàn)
@tree_provider
.parent 和
@tree_provider
.children?求各路大神幫助ORRRZ
params[
:id
].to_i 這句話的目的是在其父親的所有兒子中將自己排除掉獲得所有兄弟,結(jié)果也是各種試出來的,因為發(fā)現(xiàn)
params[
:id
]是一個字符串
def show @tree_provider = TreeProvider.find(params[:id]) @children = [] @tree_provider.tree_providers.each{|t|@children<view就太簡單啦,只是把@children和@brothers都顯示出來而已,鑒于水平太低就不貼代碼啦,運(yùn)行結(jié)果是這樣的:
上面是所有tree的list,下面是單獨(dú)的一個節(jié)點(diǎn)的信息。
很無聊的東東,聊以自high啦~
文章標(biāo)題:rails入門級開發(fā)項目——樹形分類(1)
網(wǎng)頁路徑:http://weahome.cn/article/pssjep.html