rails link_to_add_fields以嵌套形式添加两次字段

时间:2016-01-26 06:17:57

标签: javascript jquery ruby-on-rails forms nested-forms

我创建了一个包含三个模型的嵌套表单。授予模型,然后是两个嵌套模型:specs和subspecs。规格和子规都具有字段资格和不合格。我相信我已经正确设置了模型和关联,但是当我尝试使用jQuery动态添加新字段时,我的问题就出现了。我添加到资格的任何字段也会为不合格添加一个空白字段。它没有显示在表单上,​​但当我看到显示页面时,我看到它。

合格

  • A

不合格

结果将是(x为空白):

合格

  • A
  • X

不合格

  • x

当回到编辑页面时,每个x现在都有一个空白字段。我假设这是我的应用程序助手中的错误,并且每次在表单的一个部分中使用link_to_add_fields时,它会触发在另一个部分中创建字段。有趣的是,如果我回去编辑并填写空白字段,他们将保留新条目。它只是迫使我为每个部分提供相同数量的项目符号,我不想要。

module ApplicationHelper
  def link_to_add_fields(name, f, association)
    new_object = f.object.send(association).klass.new
    id = new_object.object_id
    fields = f.fields_for(association, new_object, child_index: id) do |builder|
      render(name.to_s.singularize + "_fields", f: builder)
    end
    link_to(name, '#', class: "add_fields", data: {id: id, fields: fields.gsub("\n", "")})
  end

和我的表格

<%= form_for(@grant) do |f| %>
<div class="field">
    <%= f.label :overview %><br>
    <%= f.text_area :overview %>
  </div>

<h2> Eligibility </h2>
  <%= f.fields_for :specs do |builder| %>
    <%= render 'eligibility_fields', f: builder %>
     <% end %>
     <%= link_to_add_fields "eligibility", f, :specs %>

<h2> Ineligibility </h2>
<%= f.fields_for :specs do |builder| %>
    <%= render 'ineligibility_fields', f: builder %>
     <% end %>
     <%= link_to_add_fields "ineligibility", f, :specs %>

和eligibility_fields呈现

<fieldset>
  <%= f.label :eligibility, "Eligibility" %><br />
  <%= f.text_area :eligibility %><br />
  <%= f.label :_destroy, "Remove Eligibility" %>
  <%= f.hidden_field :_destroy %>
  <%= link_to "remove", '#', class: "remove_fields" %>
  <%= f.fields_for :subspecs do |builder| %>
  <%= render 'subeligibility_fields', f: builder %>
    <% end %> 
  <%= link_to_add_fields "subeligibility", f, :subspecs %>
</fieldset>

最后是jQuery

jQuery ->
  $('form').on 'click', '.remove_fields', (event) ->
    $(this).prev('input[type=hidden]').val('1')
    $(this).closest('fieldset').hide()
    event.preventDefault()

  $('form').on 'click', '.add_fields', (event) ->
    time = new Date().getTime()
    regexp = new RegExp($(this).data('id'), 'g')
    $(this).before($(this).data('fields').replace(regexp, time))
    event.preventDefault()

我是rails的新手,尤其是jQuery,所以任何帮助都会受到赞赏!

0 个答案:

没有答案