Rails 3 - AJAX REST新表单双重提交单用户点击

时间:2013-02-03 02:14:01

标签: ajax ruby-on-rails-3

我有一个标准表格,用于AJAX提交的控制器的新操作。每次用户单击提交按钮或按一次输入时,表单立即提交两次,创建两个相同的对象。

模型上没有验证,有些情况是合适的。

表单视图如下所示:

<%= simple_form_for @contact, remote: true do |f| %>
    <table>
      <tr><td class="cell-right-align">First Name</td><td><%= f.text_field :first_name %></td></tr>
      <tr><td class="cell-right-align">Last Name</td><td><%= f.text_field :last_name %></td></tr>
      <tr><td></td><td><%= f.submit "Create Contact" %></td></tr>
  </table>
<% end %>

它的控制器操作:

def create
  respond_to do |format|
    if @contact.save
      format.js { render 'search_result' }
    else
      format.js { render 'new' } 
    end
  end
end

创建操作的日志显示,在同一秒内有两个POST操作,两者都相同。

如何停止双重POST?我尝试将:disable_with => 'Saving...'添加到提交按钮,但没有效果。

1 个答案:

答案 0 :(得分:0)

这可能是资产管道问题。您是否可以在生产模式下运行应用程序并验证资产是否已预编译。我怀疑用于处理提交的javascript是重复的。因此,将两个相同的事件绑定到表单提交。