以下是我的模特:
class Lesson < ActiveRecord::Base
belongs_to :topic, :polymorphic => true
validates_presence_of :topic_type, :topic_id
end
class Subject < ActiveRecord::Base
has_many :lessons, :as => :topic
end
class Category < ActiveRecord::Base
has_many :lessons, :as => :topic
end
现在,我需要的是一个允许用户创建或更新课程的表单。问题是,我如何提供一个提供主题和类别混合的选择菜单? (对于用户来说,在这个特定的表格中,主题和类别是可以互换的,但在其他地方并非如此。)
理想情况下,这看起来像这样:
views / lessons / _form.html.haml
= simple_form_for(@lesson) do |f|
= f.input :title
= f.association :topic, :collection => (@subjects + @categories)
这不起作用,因为我们只指定topic_id,我们也需要topic_types。但是我们如何指定这些价值呢?
我想问题的症结在于我真的想要一个单一的选择菜单,它指定两个对应于两个不同属性的值(topic_id和topic_type)。有没有优雅的方式来做到这一点?
一些注意事项:
a)单表继承会使这个问题消失,但我想避免这种情况,因为类别和主题有自己的关系......我会饶有你的细节。
b)我可能会拉一些javascript shenanigans,是吗?但这听起来很混乱,如果有一种更清洁的方式,一些神奇的形式助手或其他东西,那么这当然更可取。c)虽然我使用的是simple_form,但我不会坚持使用它,以防万一重要。
由于
答案 0 :(得分:-1)
如果您不想使用STI,您可以执行类似的操作:创建一个新模型Topic(name:string)
,它将多态引用Subject
或Category
。
class Lesson < ActiveRecord::Base
belongs_to :topic
validates_presence_of :topic_id
end
class Topic < ActiveRecord::Base
belongs_to :topicable, :polymorphic => true
end
class Subject < ActiveRecord::Base
has_one :topic, :as => :topicable
has_many :lessons, :through => :topic
accepts_nested_attributes_for :topic
end
class Category < ActiveRecord::Base
has_one :topic, :as => :topicable
has_many :lessons, :through => :topic
accepts_nested_attributes_for :topic
end
在您创建新主题/类别的视图中:
<%= form_for @subject do |subject_form| %>
<%= subject_form.fields_for :topic do |topic_fields| %>
<%= topic_fields.text_field :name %>
<% end %>
<% end %>
答案 1 :(得分:-1)
经过深思熟虑后,IMO聘请JS恶作剧的实施程度越低(b):
= f.input_field :topic_type, as: :hidden, class: 'topic_type'
- (@subjects + @categories).each do |topic|
= f.radio_button :topic_id, topic.id, {:'data-type' => topic.class.name, class: 'topic_id'}
撒上JS(您的需求可能会有所不同):
$('input:radio.topic_id').change(function() {
$('input:hidden.topic_type').val($(this).attr('data-type'));
});
注意: