Как перезагрузить JavaScript после частичного рендеринга?

Есть продукты, которые имеют много изображений. В шаблоне редактирования продукта есть частичное добавление и удаление изображений.

_edit_images.html.erb

<% if @product.images != nil && @product.images.count > 0 %>
   <ul id="images_index" data-update-url="<%= sort_images_url %>">
   <% @product.images.order( :position ).each do |i| %>
      <%= content_tag_for :li, i do %>
         <%= image_tag i.image.url( :thumb ), class: "img-polaroid"  %>
         <%= link_to image_tag('icons/remove.png'), remove_image_from_product_products_path( product_id: @product.id, image_id: i.id ), remote: true, method: :get, data: { confirm: "Sure?"}, class: 'delete_item' %>
      <% end %>
   <% end %>
   </ul>
<% end %>
<a class="btn btn-default" id='add_image' href="#add_image_form"><span class="glyphicon glyphicon-plus"></span></a>
<%= form_tag '/admin/images', remote: true, multipart: true,  id: 'add_image_form' do %>
   <input type="hidden" name="authenticity_token" value="<%= form_authenticity_token %>" />
   <input type="hidden" name="product_id" value="<%= @product.id %>" />
   <br><%= label_tag 'name', 'Image title' %>
   <%= text_field_tag 'title', '', id: "add_image_title", class:'form-control' %><br>
   <%= label_tag 'name', 'Выберите файл' %>
   <%= file_field_tag 'file', class:'form-control'%><br><br>
   <button type="submit" class="btn btn-primary">Add image</button>
<% end %>

Форма вызывает контроллер действия над изображениями

  def create
     image = Image.create( title: params[ :title ], image: params[ :file ] )
     @product = Product.find_by id: params[ :product_id ]
     @product.images << image
     respond_to do |format|  
        format.html { redirect_to admin_products_path }  
        format.js   { render '/products/edit_images' }  
     end  
  end

После того, как изображение было добавлено и отклонено, JavaScript не работает. Может кто-нибудь предложить способ перезагрузить JavaScript после рендеринга частично?

ОБНОВЛЕНИЕ images.js.coffee

jQuery ->
  $("a#add_image").on "click", (e) ->
    $("form#add_image_form").toggle()
    e.preventDefault()

  $('div.actions ul#images_index').sortable
    axis: 'y'
    update: ->
      $.post($(this).data('update-url'), $(this).sortable('serialize'))

1 ответ

Ответ прост. Установка прослушивателей событий при обновлении страницы решает проблему

images_update = ->
  $("#add_page_image").on "click", (e) ->
    $("form#add_image_form").toggle()
    e.preventDefault()

  $('#page_images_index').sortable
    axis: 'y'
    update: ->
      $.post($(this).data('update-url'), $(this).sortable('serialize'))

$(document).on 'page:update', ->
  images_update()
Другие вопросы по тегам