在Rails 4中发送带有远程true的表单

Nic*_*nto 7 forms ajax ruby-on-rails ruby-on-rails-4

我有一个用于更新图像的表单

<%= form_for current_user, url: update_image_user_path(current_user), method: :post, html: {multipart: :true, remote: true},  :authenticity_token => true do |f| %>
Run Code Online (Sandbox Code Playgroud)

行动有

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

但我收到以下错误

ActionView::MissingTemplate - Missing template users/update_image, application/update_image with {:locale=>[:en], :formats=>[:html], :handlers=>[:erb, :builder, :raw, :ruby, :coffee]}.
Run Code Online (Sandbox Code Playgroud)

我没有update_image.html.erb模板,但是从错误中我得知请求不是以js格式发送的

我错过了什么?

Phi*_*899 6

你应该知道几件事.

  1. Ajax使用称为xmlhttprequest的东西来发送数据.不幸的是,xmlhttprequests无法发布文件.Remotipart可能有效,但在jqueryfileupload上有更多的文档和轨道投射视频.它被许多站点使用(很多站点甚至不使用rails).我建议使用jqueryfileupload-rails gem和rails cast:

    A. https://github.com/tors/jquery-fileupload-rails
    B. http://railscasts.com/episodes/381-jquery-file-upload

  2. remote:true不是html属性.改变你的代码:

    <%= form_for current_user, url: update_image_user_path(current_user), 
        method: :post, html: {multipart: :true}, remote: true,  
        :authenticity_token => true do |f| %>
    
    Run Code Online (Sandbox Code Playgroud)

您遇到的错误中最重要的部分是:

:formats=>[:html]
Run Code Online (Sandbox Code Playgroud)

应该说:

:formats=>[:js]
Run Code Online (Sandbox Code Playgroud)

使用remote:现在在正确的位置为true,错误应该消失.


San*_*pil 5

rails remote true不适用于图像上传.您不能仅使用远程true来使用ajax上传图像.你需要jquery.form.js文件给用户ajaxForm.对于这包括

    <script src="http://malsup.github.com/jquery.form.js"></script>
Run Code Online (Sandbox Code Playgroud)

绑定表单

     $("#formid").ajaxForm()
Run Code Online (Sandbox Code Playgroud)

或者,您可以使用jqueryfileupload-rails gem

https://github.com/tors/jquery-fileupload-rails


iro*_*and 2

html: {multipart: :true}, remote: true代替怎么样html: {multipart: :true, remote: true}