【问题标题】:Nested form in a table, not working表格中的嵌套表格,不起作用
【发布时间】:2015-06-05 08:56:19
【问题描述】:

有人可以帮助我了解如何将嵌套表单放入表格中吗?

我的代码:

#app/view/master_templates/edit.html.erb
<%= form_for(@master_template) do |f| %>     
  <%= f.label :name %><br />
  <%= f.text_field :name %>

  <table border="1">
    <%= f.fields_for :master_template_details, :wrapper => false do |p| %>
      <%= render 'master_template_detail_fields', {f: p} %>
    <% end %>
    <tr><td><%= link_to_add_fields "Add Details", f, :master_template_details %></td></tr>
  </table>

  <div class="actions">
    <%= f.submit %>
  </div>
<% end %>

#app/views/master_templates/_master_template_details_fields.html.erb
<tr class="fieldset">
  <td><%= f.hidden_field :id %></td>
  <td><%= f.select :field_type_id, options_from_collection_for_select(FieldType.all, :id, :name, f.object.field_type_id) %></td>
  <td><%= f.hidden_field :_destroy %></td>
  <td><%= link_to "Remove Detail", '#', class: "remove_fields" %></td>
</tr>

#app/helpers/application_helper.rb.
  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(association.to_s.singularize + "_fields", f: builder)
    end
    link_to(name, '#', class: "add_fields btn", data: {id: id, fields: fields.gsub("\n", "")})
  end

#app/assets/application.js.coffee
jQuery ->
  # Remove fieldset
  $('form').on 'click', '.remove_fields', (event) ->
    $(this).prev('input[type=hidden]').val('true')
    $(this).closest('fieldset').hide()
    event.preventDefault()

  # Add more fieldset
  $('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()

当我尝试点击添加详细信息链接时,它会在添加详细信息链接的&lt;td&gt; 内创建&lt;fieldset&gt;*details*&lt;/fieldset&gt;Remove Detail 链接不工作,但没有表格它工作。

我找到了this,但它不起作用或者我做错了。我是嵌套、ROR 和 js 方面的菜鸟。请帮忙详细说明。谢谢

【问题讨论】:

  • $(this).closest('fieldset').hide() 这是标签fieldset。您正在将字段集用作类,因此请使用此 $(this).closest('tr.fieldset').hide()
  • 感谢您的回答。我使用了您的想法并将其用于我的 add_fields 函数 $(this).closest('tr').before($(this).data('fields').replace(regexp, time)) 。现在它正在工作。

标签: javascript ruby-on-rails ruby-on-rails-4 nested-forms fields-for


【解决方案1】:

试试它是否有效。我不太确定。

$('form').on 'click', '.remove_fields', (event) ->
$(this).parent().prev().find('input[type=hidden]').val('true')
$(this).parent().parent().hide()
event.preventDefault()


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

【讨论】:

  • 我的主要问题是添加详细信息链接。它正在工作,但不是正确的&lt;tr&gt;
  • 谢谢你。它现在可以工作了,但我使用了 @Pardeed Dhingra remove_fields 函数。
  • 我使用$(this).closest('tr').before($(this).data('fields').replace(regexp, time)) 作为我的 add_fields 函数。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-12-26
  • 1970-01-01
  • 2014-08-17
  • 2014-11-25
  • 1970-01-01
相关资源
最近更新 更多