rails入门级开发项目——树形分类(1)

今天要做的是这么个东东,先上数据库:

成都创新互联专注于企业网络营销推广、网站重做改版、临潭网站定制设计、自适应品牌网站建设、H5高端网站建设成都做商城网站、集团公司官网建设、成都外贸网站建设公司、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为临潭等各大城市提供网站开发制作服务。

rails入门级开发项目——树形分类(1)

是一个简单的树形结构,一个tree_id对应一个parent_id,相当于对应一个父节点,涉及到了自身的连接关系,其实还是挺复杂的数据库设计,起码当初这个设计是怎么也木有看懂~

想要达到的想法是动态的在节点上增删改,可以用鼠标各种拖动换parent那种。不过现在的本事只能做成静态的,现在的状态是点击某一节点的链接会显示自己,父亲,儿子,以及兄弟。

闲话少说,上代码:

数据库生成部分,很简单的两个属性,注意id:false这句话,这是ruby 1.9之后才支持的特性,其实等同于 :id => false ,也就是说没有在这个表中给规定rails默认的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后面跟复数,belongs_to后面放单数~~而且这两者同样的foreignkey都是parent_id,但是意思却是不一样的。前者是把自己作为主键,parent_id是别人的,后者相反,parent_id是自己的~这是我现在的理解。放了一个验证函数,保证在save之前执行,确保自己不能是自己的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的区别,其实这样表示很没有区分啦,所以一个现在解决不了的问题来了,如何才能实现@tree_provider.parent 和@tree_provider.children?求各路大神帮助ORRRZparams[:id].to_i 这句话的目的是在其父亲的所有儿子中将自己排除掉获得所有兄弟,结果也是各种试出来的,因为发现params[:id]是一个字符串

def show
   @tree_provider = TreeProvider.find(params[:id])
   @children = []
   @tree_provider.tree_providers.each{|t|@children<

view就太简单啦,只是把@children和@brothers都显示出来而已,鉴于水平太低就不贴代码啦,运行结果是这样的:

rails入门级开发项目——树形分类(1)

上面是所有tree的list,下面是单独的一个节点的信息。

rails入门级开发项目——树形分类(1)

很无聊的东东,聊以自high啦~

当前题目:rails入门级开发项目——树形分类(1)
文章来源:http://myzitong.com/article/pssjep.html