在rails 4中上传Jquery文件

Bla*_*ist 7 jquery ruby-on-rails ruby-on-rails-4

大家好,我正在http://railscasts.com/episodes/381-jquery-file-upload上关注Jquery文件上传的视频教程,我被困了.我上传图像后,我的渲染部分不刷新,它将新图像和所有其他图像添加到已附加的图像下.因此,如果我将两个图像添加到新项目中,则显示第一个图像,然后使用第一个图像再次渲染局部图像,并在第一个图像下再渲染第二个图像,因此总共有3张照片.

这是我的create.js.erb

<% if @photo.new_record? %>
  alert("Failed to upload photo: <%= j @photo.errors.full_messages.join(', ').html_safe %>");
<% else %>
  $("#photos").append("<%=j render @photo %>");
<% end %>
Run Code Online (Sandbox Code Playgroud)

这是我的展示页面中的渲染.

<div id="photos">
    <%= render 'photos/photo' %>
</div>
Run Code Online (Sandbox Code Playgroud)

这是我的/photos/_photos.html.erb部分

<h2>Images</h2>
<div class="photo">
<% @rental.photos.each do |photo| %>
  <p>
    <strong>Photo:</strong>
    <%= image_tag photo.image_url.to_s %>
    </script>   
  </p>
 <% end %>
</div>
Run Code Online (Sandbox Code Playgroud)

这是我的照片控制器创建

 def create
    @rental = Rental.find(params[:rental_id])
    @photo = @rental.photos.create(params[:photo].permit(:image))

    respond_to do |format|
      format.js
    end
  end
Run Code Online (Sandbox Code Playgroud)

这是我的照片.js.jcoffee

jQuery ->
  $('#new_photo').fileupload(replaceFileInput: false,
    paramName: 'photo[image]')


    dataType: "script"
    add: (e, data) ->
      types = /(\.|\/)(gif|jpe?g|png)$/i
      file = data.files[0]
      if types.test(file.type) || types.test(file.name)
        data.context = $(tmpl("template-upload", file))
        $('#new_photo').append(data.context)
        data.submit()
      else
        alert("#{file.name} is not a gif, jpeg, or png image file")
    progress: (e, data) ->
      if data.context
        progress = parseInt(data.loaded / data.total * 100, 10)
        data.context.find('.bar').css('width', progress + '%')
Run Code Online (Sandbox Code Playgroud)

任何帮助都会很棒,我被困住了.谢谢!


非常感谢Rich Peck,他的回答完全解决了我的问题.我不得不改变

<% if @photo.new_record? %>
  alert("Failed to upload photo: <%= j @photo.errors.full_messages.join(', ').html_safe %>");
<% else %>
  $("#photos").append("<%=j render @photo %>");
<% end %>
Run Code Online (Sandbox Code Playgroud)

<% if @photo.new_record? %>
  alert("Failed to upload photo: <%= j @photo.errors.full_messages.join(', ').html_safe %>");
<% else %>
  $("#photos").html("<%=j render @photo %>");
<% end %>
Run Code Online (Sandbox Code Playgroud)

Ric*_*eck 2

def create
    @rental = Rental.find(params[:rental_id])
    @photo = @rental.photos.create(params[:photo].permit(:image))

    respond_to do |format|
        format.js
    end
end
Run Code Online (Sandbox Code Playgroud)

这是我第一次看到它


修复实际上是用来$('#photos').html()更换容器。OP最初.append只是用来将内容附加到容器中,这根本不能很好地工作