如何在Rails

时间:2016-03-20 09:36:48

标签: javascript ruby-on-rails json ruby-on-rails-4 coffeescript

我正在尝试在ajax表单上显示提交失败的错误消息。我之前没有走过ajax表单的路径,也无法找到一个可靠的最新指南,了解如何在表单因任何原因无法保存数据时显示错误消息。

我在控制器中有一个失败的表单提交format.json { render :json => { :errors => @key.errors.full_messages }, :status => 422 },如下所示。但我不知道JS或coffeescript有什么,所以显示错误消息。

category_item_keys控制器

def new
   @guide      = Guide.friendly.find params[:guide_id]
   @category   = Category.friendly.find params[:category_id]
   @key        = @category.category_item_keys.new
end


def create

    @guide      = Guide.friendly.find params[:guide_id]
    @key        = @category.category_item_keys.new key_params
    @category   = Category.friendly.find params[:category_id] 


 if @key.save

    CategoryItemKey.find(@key.id).update(submitted_by: current_user.id, approved_by: current_user.id, guide_id: @guide.id)

    respond_to do |format|

     format.html {  redirect_to new_guide_category_category_item_key_path(@guide, @category)
              flash[:success] = "Key added successfully!"  }

     format.json { render :json }
     format.js 

     end

 else
    respond_to do |format|
      format.html {  render 'new' }
      format.json { render :json => { :errors => @key.errors.full_messages }, :status => 422 }
    format.js 
   end
 end

end

def key_params
   params.require(:category_item_key).permit(:name, :key_type)
end

new.html.erb

<%= form_for([@guide, @category, @key], url: guide_category_category_item_keys_path, remote: true, :authenticity_token => true) do |f| %>
   <%= render 'shared/error_messages', object: f.object %>

   <%= f.label :name, "Key name" %>
   <%= f.text_field :name %>

   <%= f.select :key_type, [['Stat', 1], ['Attribute', 2], ['Image', 3], ['Text', 4]] %>

   <%= f.submit "Next"  %>
<% end %>

category_item_key.coffee

# No idea what is needed in here

我已经阅读了所有可以找到的帖子,看看category_item_key.coffee中需要什么,但它们都是3 - 5年,只是不起作用。我确信它并不复杂,但我对JS的了解并不多。

1 个答案:

答案 0 :(得分:2)

category_item_keys控制器:

format.json { render :json => @key.errors, :status => 422 }

_save.js.erb

<% if @key.errors.any? %>
  $("<%= j(render 'shared/error_messages') %> ").prependTo('#YoursFormId');
<% else %>
  // do something when no errors
<% end %>

create.js.erb,update.js.erb

<%= render 'save' %>