Hier ist der grundlegende Ansatz, den ich in einer meiner Apps gewählt habe. Problem hat viele Antworten - Problem ist ein Dokument, Antwort ist ein eingebettetes Dokument. Sie können den Link "Antwort hinzufügen" verwenden, um ein weiteres Antwortfeld zu erstellen, und den Link "Entfernen", um eines zu löschen.
_form.html.erb:
<% form_for @problem do |f| %>
<%= f.error_messages %>
<p>
<%= f.label :content %><br />
<%= f.text_area :content, :size => '50x7' %>
</p>
...etc...
<%= add_answer_link "(add answer)" %>
<div id="answers">
<%= render :partial => 'answer', :collection => @problem.answers %>
</div>
<p><%= f.submit "Submit" %></p>
<% end %>
_answer.html.erb:
<div class="answer">
<% fields_for 'problem[answers]', answer, :index => nil do |f| -%>
<%= f.label :content, "Answer #{answer.id}:" %>
<%= f.text_field :content, :size => 50 %>
<%= link_to_function "(remove)", "$(this).up('.answer').remove()" %>
<% end -%>
</div>
problems_helper.rb
module ProblemsHelper
def add_answer_link(name)
link_to_function name do |page|
page.insert_html :bottom, "answers", :partial => 'answer', :object => Answer.new
end
end
end
Ich habe ein paar kleine Teile der Implementierung herausgeschnitten, aber das sollte funktionieren.