0

我有很多主要类别,想添加到每个子类别中。->

主类
-子类
-子类
-子类

主类
-子类
-子类
-子类

很多人建议我使用 gem,但由于我对 Rails 还很陌生,所以我宁愿自己学习如何做到这一点,并从头到尾学习。

我应该从 aScaffold还是简单的 a开始Model

有人可以解释我如何开始(迁移等)以及如何设置它吗?

谢谢你。

4

1 回答 1

6

您必须使用 生成一个新模型rails g model category,然后编辑文件生成db/migrate并写入

class CreateCategories < ActiveRecord::Migration
    def change
        create_table :categories do |t|
            t.belongs_to :category
            t.string :name, :null => false
            t.timestamps
        end
    end
end

并编辑app/models/category.rb

class Category < ActiveRecord::Base

    belongs_to :category
    has_many :children, :dependent => :destroy, :class_name => 'Category'

end

您必须执行rake db:migrate在数据库中创建表。

编辑:

在 app/controllers/categories_controller.rb

class CategoriesController < ApplicationController

    def index
        @categories = Category.all
    end

    def new
        @category = Category.new
    end

    def edit
        @category = Category.find(params[:id])
    end

    def create
        @category = Category.new(params[:category].permit!)
        if @category.save
            redirect_to categories_url
        else
            render :new
        end
    end

    def update
        @category = Category.find(params[:id])
        if @category.update_attributes(params[:category].permit!)
            redirect_to categories_url
        else
            render :edit
        end
    end

    def destroy
        Category.destroy(params[:id])
        redirect_to categories_url
    end

end

以及您的类别的表格:

<%= form_for @category do |f| %>

    <%= f.text_field :name %>
    <%= f.select :category_id, options_from_collection_for_select(Category.all, :id, :name, @category.category_id), :include_blank => true %>

    <%= f.submit %>

<% end %>
于 2013-08-14T17:03:45.427 回答