我在我的项目中有一个模型Artworks的窗体,其中我使用fields_for作为资源Photo,其中Artworks has_many :photos。
Photo模型使用回形针附加图像。
我的所有表单都是基于AJAX的,这意味着页面永远不应该重新加载,并且我不应该在控制器中的任何地方使用redirect_to (我没有)。
当我使用回形针file_field在表单中包含fields_for时,如果我在提交表单时创建或更新照片,则会收到以下错误:
Template is missing
Missing template artworks/show, application/show with {:locale=>[:en], :formats=>[:html], :handlers=>[:erb, :builder, :coffee]}. Searched in: * "/home/david/rails/piml_artwork/app/views" * "/home/david/.rvm/gems/ruby-1.9.3-p194/gems/devise-2.1.2/app/views"销毁映像复选框按预期工作。更新表单上的其余详细信息并提交它的功能与预期一样,只需返回一个AJAX响应并填写页面。
我的artworks控制器如下:
class ArtworksController < ApplicationController
before_filter :load
authorize_resource
respond_to :html, :json, :js
def load
end
def show
@artwork = Artwork.find(params[:id])
end
def index
@artworks = Artwork.all
end
def new
@artwork = Artwork.new
@artwork.photos.build unless @artwork.photos.count > 0
end
def create
@artwork = Artwork.new(params[:artwork])
if @artwork.save
flash[:notice] = "Artwork saved"
@artworks = Artwork.all
respond_with @artwork
end
end
def edit
@artwork = Artwork.find(params[:id])
@artwork.photos.build unless @artwork.photos.count > 0
end
def update
@artwork = Artwork.find(params[:id])
if @artwork.update_attributes(params[:artwork])
flash[:notice] = "Artwork updated"
@artworks = Artwork.all
respond_with @artwork
end
end
def destroy
@artwork = Artwork.find(params[:id])
@artwork.destroy
flash[:notice] = "Artwork destroyed"
@artworks = Artwork.all
end
end引起冲突的形式如下:
<%= form_for( @artwork, remote: true, mutlipart: true ) do |f| %>
<%= render 'layouts/error_messages', object: f.object %>
<div id="artwork-title">TITLE: <%= f.text_field :title %></div>
<div id="artwork-title-underline"></div>
<div id="artwork-show-picture"><%= image_tag @artwork.photos.first.photo.url(:medium) unless @artwork.photos.first.new_record? %>
<div id="artwork-picture-upload">
<%= f.fields_for :photos, remote: true, multipart: true do |p| %>
<% if p.object.new_record? %>
UPLOAD PHOTO
<%= p.file_field :photo, value: 'Upload Image' %>
<% else %>
REPLACE PHOTO
<%= p.file_field :photo, value: 'Replace Image' %>
<br />
<br />
<%= p.check_box :_destroy %>
<%= p.label :_destroy, 'Delete Image' %>
<% end %>
<% end %>
</div>
</div>
<div id="artwork-public">
ARTIST<br />
<%= f.select :artist_id, Artist.select_list, include_blank: "SELECT ARTIST" %><br />
<br />
DATE OF WORK <br />
<%= f.text_field :date_of_work %><br />
<br />
<div id="artwork-modify-buttons">
<%= f.submit %>
</div>
<% end %>我要更新的JS文件是:
<% if !@artwork.errors.any? %>
$("#facebox .content").html("<%= escape_javascript(render(partial: "/artworks/show")) %>");
$("#artworks-col").html(" <%= escape_javascript(render(partial: "/admin/artworks_list" )) %>")
<% else %>
$("#facebox .content").html("<%= escape_javascript(render(partial: "/artworks/form")) %>");
<% end %>发布于 2012-10-13 11:21:54
事实证明,我遇到的问题是,根据设计,您不能通过AJAX上传文件。
经过几天的努力,我发现了一个非常容易解决所有问题的宝石:Remotipart
我要做的全部事情是:
//= require jquery.remotipart添加到我的应用程序/assets/javascripts/Application.js remotipart这解决了它。图片现在正在上传“看起来像”AJAX的东西,但实际上是使用iframe来完成这项工作。
https://stackoverflow.com/questions/12858528
复制相似问题