我有一个这样的嵌套表格:
<% form_for setup_training(@training), :url => admin_trainings_path, :html => { :class => :form } do |f| -%>
<!-- begin of form -->
<!-- content of :partial => "day_form" -->
<% f.fields_for :days do |days_form| %>
<%= render :partial => "admin/days/form_inner", :locals => { :f => days_form }%>
<% end %>
<!-- end of content of :partial => "day_form" -->
<%= link_to_function("[+] Ajouter une date", nil, :id => "add-place-and-dates-link") do |page|
page.insert_html :bottom, "place-and-dates-inner", :partial => "day_form", :locals => { :f => f }
end %>
<% end -%>
我第一次加载页面时,第一个fields_for块的id为0;
我第一次点击“添加日期”时,会创建一个id = 1的新fields_for块;
然后,每当我发送“添加日期”时,都会显示一个新的fields_for块,但id保持为1。
HTML示例可能更明确,这是我得到的输出:
<!-- This part is generated when i display /new, id is 0 -->
<label class="label" for="training_days_attributes_0_place_id">Lieu</label>
<input class="text_field" id="training_days_attributes_0_place_id" name="training[days_attributes][0][place_id]" size="30" type="text">
<!-- This part is generated when i click on "add a new date", id is 1 -->
<label class="label" for="training_days_attributes_1_place_id">Lieu</label>
<input class="text_field" id="training_days_attributes_1_place_id" name="training[days_attributes][1][place_id]" size="30" type="text">
<!-- This part is generated when i click on "add a new date" a second time, id is 1, but it should be 2 -->
<label class="label" for="training_days_attributes_1_place_id">Lieu</label>
<input class="text_field" id="training_days_attributes_1_place_id" name="training[days_attributes][1][place_id]" size="30" type="text">
谢谢您的帮助!
答案 0 :(得分:0)
如果您在页面源中查看内联javascript,您会看到您的link_to_function包含静态html,它将被插入到place-and-dates-inner容器中。这不会改变,因为它是在服务器上构建并发送给用户的。
要解决此问题,您可能最好将客户端数量先前插入到place-and-dates-inner中的容器数量计算,并相应地在模板中递增。这种内联link_to_function的东西我总是不喜欢说实话。