Rails,Cocoon,嵌套表单无法正确保存

时间:2015-07-15 23:00:42

标签: ruby-on-rails nested-forms cocoon-gem

嗨我有一个带有导轨和茧的嵌套表格。我测试了几个小时的所有内容并尝试了相关主题中的所有建议但没有任这是我的设置:

student.rb(斯图登模特)

    has_many :parents, dependent: :destroy
    accepts_nested_attributes_for :parents,
                                reject_if: proc { |attributes|    
                                attributes['first_name'].blank? },
                                :allow_destroy => true

学生/ new.html.erb

  <div class="content <% if !@active_tab %> active <% end %>" id="tabStudent">
    <%= form_for @student, validate: true do |student| %>

      <%= render 'student_fields', model: student %>
      <%= hidden_field(:active, 'tab', value: @active_tab) %>
  </div>

  <div class="content <% if @active_tab === 'tabParents' %> active <% end %>" id="tabParents">
      <h2>Parents</h2>

      <div id="parents">
        <%= student.fields_for :parents do |parent| %>
          <%= render partial: 'parent_fields', locals: {include_mode: 'new', f: parent, added_by: ''}  %>
        <% end %>

      <%= link_to_add_association 'add', student, :parents,
                                   render_options: { locals: {include_mode: 'new', added_by: 'rails'}},
                                  'data-association-insertion-node' => '#parents',
                                  'data-association-insertion-method' => 'append' %>
      </div>

   </div>

students_controller.rb

def create
  @student = Student.new(student_params)
  @student.parents.build

  if @student.save
    flash[:success] = "Success"
    redirect_to @student
  else
    render 'new'
  end
end
private
    def student_params
      params.require(:student).permit(:first_name, :last_name, :gender,
      parents_attributes: [:id, :first_name, :last_name, :gender, :_destroy])
    end

学生/ _parent_fields.html.erb

<div class="nested-fields">
      <div class="row links">
        <div class="large-12 columns right">
          <%= link_to_remove_association raw('<i style="color:#ff0000;" class="fi-x-circle"></i>'), f %>
       </div>
      </div>



    <div class="row">
      <fieldset>
        <legend>Data</legend>
        <div class="row">
          <div class="large-3 columns field">
            <%= f.label :gender, 'Student Gender' %>
            <%= f.select(:gender, [['male', 'm'], ['female', 'f']]) %>
          </div>

          <div class="large-3 columns field">
            <%= f.label :first_name, 'First Name' %>
            <%= f.text_field :first_name %>
          </div>
          <div class="large-3 columns field">
            <%= f.label :last_name, 'Last Name' %>
            <%= f.text_field :last_name %>
          </div>
      </fieldset>
    </div>
</div>

到目前为止,我可以添加和删除表单字段,但是当我发送它时,只有第一个父节点被保存到数据库中。如果我使用&#34添加第二个父项;添加&#34;链接空记录保存到数据库。第二种形式也没有显示在帖子数据中,所以记录是空的并不奇怪,但我无法弄清楚数据传输不正确的原因。

编辑:我找到了问题所在。我使用curb-foundation作为css样式,对于嵌套表单我使用&#34; tabs&#34;:

<div class="tabs-content">

  <div class="content <% if !@active_tab %> active <% end %>" id="tabStudent">
<%= form_for @student, validate: true do |student| %>

    <%= render 'student_fields', model: student %>
    <%= hidden_field(:active, 'tab', value: @active_tab) %>


    </div>
    <div class="content <% if @active_tab === 'tabParents' %> active <% end %>" id="tabParents">
      <h2>Parents</h2>

      <div id="parents">
        <%= student.fields_for :parents do |parent| %>
          <%= render partial: 'parent_fields', locals: {include_mode: 'new', f: parent, added_by: ''}  %>
        <% end %>

      <%= link_to_add_association 'new', student, :parents,
                                   render_options: { locals: {include_mode: 'new', added_by: 'rails'}},
                                  'data-association-insertion-node' => '#parents',
                                  'data-association-insertion-method' => 'append' %>
      </div>

    </div>

嵌套的div似乎打破了茧的功能。如果我删除div它工作。有没有人知道如何制定一个允许我使用标签的解决方案?

1 个答案:

答案 0 :(得分:2)

谜语解决了。由于@student.parents.build而产生了空记录。 Cocoon不需要这个命令。

主要问题是通过将@form_for部分从第一个基础选项卡中移出一层来解决,因此它会显示在每个选项卡上方。然后我写了一个小查询函数,只在第一个选项卡中将它呈现给用户。