0

Может кто-нибудь помочь мне в том, как я поместил свою вложенную форму в таблицу?Вложенная форма в таблицу, не работает

мой код:

#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() 

Когда я попытался нажать Добавить Подробнее ссылки, она будет создавать <fieldset>*details*</fieldset> внутри <td> С Детали ссылки. И Удалить деталь ссылка не работает, но без таблицы она работает.

Я нашел this, но это не работает, или я делаю это неправильно. Я нооб во вложенном, ROR и js. Пожалуйста, помогите подробнее. Спасибо

+1

'$ (this) .closest ('fieldset'). Hide()' это для тега 'fieldset'. Вы используете fieldset как класс, поэтому используйте этот '$ (this) .closest ('tr.fieldset'). Hide()' –

+1

Благодарим вас за ответ. Я использовал вашу идею и использовал ее для моей функции add_fields '$ (this) .closest ('tr'). Before ($ (this) .data ('fields'). Replace (regexp, time)). И теперь он работает. –

ответ

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() 
+0

моей главной проблемой является ссылка «Добавить данные». Он работает, но не в правильном ''. –

+0

обновленный ans, пожалуйста, проверьте его – bunty

+1

Спасибо за это. Теперь он работает, но я использовал функцию ** @ Pardeed Dhingra ** remove_fields. –

Смежные вопросы