让这个工作变得有点麻烦。
class User < ActiveRecord::Base
has_many :events, :through => :event_users
has_many :event_users
accepts_nested_attributes_for :event_users, :allow_destroy => true, :reject_if => proc { |obj| obj.blank? }
end
class Event < ActiveRecord::Base
has_many :event_users
has_many :users, :through => :event_users
accepts_nested_attributes_for :users, :reject_if => lambda { |a| a[:nick].blank? }, :allow_destroy => true
end
class EventUser < ActiveRecord::Base
set_table_name :events_users
belongs_to :event
belongs_to :user
end
表布局:
events_users
user_id
event_id
is_participating
events
id
name
users
id
name
这是表格
的代码<%= form_for @event do |f| %>
<%= f.fields_for :users, f.object.users do |builder| %>
<%= builder.text_field :name, "Name" %>
<%= f.fields_for :event_users do |builder2| %>
<%= builder2.hidden_field :is_participating, :value => true %>
<% end %>
<% end %>
<% end %>
我想要完成的是在events_users表中设置字段is_participating,但它不起作用!
答案 0 :(得分:1)
我有同样的问题,基本上我做的是以下内容:
<%= form_for @event do |f| %>
<%= f.fields_for :event_users, @event_user do |builder| %>
<%= builder.hidden_field :is_participating, :value => true %>
<%= f.fields_for :users, f.object.user do |builder2| %>
<%= builder2.text_field :name, "Name" %>
<% end %>
<% end %>
<% end %>
即,我切换了嵌套对象的顺序。这要求您通过声明的连接表(您执行此操作)建立关系。它为我保存了三个表中的所有属性。
但是,如果你想保留当前的模型,我想知道你是否应该为第一级嵌套表单设置相同的设置。也就是说,你的f.fields_for:event_users后面应该跟一个逗号和该类的实例。
答案 1 :(得分:0)
您的events_users表是否没有'id'字段作为主键?如果您发布了events_users连接表的表格布局,可能会有所帮助。