在我的控制器中,我想做以下事情:
class SubsController < ApplicationController
def push_sub
@sub = Sub.find(params[:id])
@food = Food.find("ID of food selected from collection_select") => see my form down below
@food.subs << @sub
end
private
def sub_params
params.require(:sub).permit(:name, :description)
end
end
@food.subs 返回一个 ActiveRecord::Associations::CollectionProxy ,例如:
=> #<ActiveRecord::Associations::CollectionProxy [#<Sub id: 34, name: "Fake choco", description: "cacao fake", created_at: "2015-01-07 23:40:25", updated_at: "2015-01-07 23:40:25">, #<Sub id: 34, name: "Fake choco", description: "cacao fake", created_at: "2015-01-07 23:40:25", updated_at: "2015-01-07 23:40:25">, #<Sub id: 34, name: "Fake choco", description: "cacao fake", created_at: "2015-01-07 23:40:25", updated_at: "2015-01-07 23:40:25">]>
在我的表单中单击 f.submit 时,它会触发 push_sub 操作,该操作将新的@sub 推送到所选项目 (@food) 的关联中。
我不知道如何在我的表单中获取所选食物的 ID,以便我可以在我的控制器中使用它。
这是我的表格:
<%= form_for @sub, :url => {:action => "push_sub"} do |f| %>
<h1>What food is <%="#{@sub.name}"%> a substitute of?</h1>
<div class="field">
<%=collection_select(:sub, :foods, Food.all, :id, :name)%>
</div>
<div class="actions">
<%= f.submit %>
</div>
<% end %>
非常感谢您的帮助。
大家新年快乐 !
安托万
更新
我有 3 个具有 has_many through 关系的模型:食物(例如:巧克力)、子(巧克力食品替代品)、联合(联合表)。
class Food < ActiveRecord::Base
has_many :joints
has_many :subs, :through => :joints
accepts_nested_attributes_for :subs, reject_if: :all_blank, allow_destroy: true
end
class Sub < ActiveRecord::Base
has_many :joints
has_many :foods, :through => :joints
accepts_nested_attributes_for :foods, reject_if: :all_blank, allow_destroy: true
end
class Joint < ActiveRecord::Base
belongs_to :food
belongs_to :sub
end