如何在 Rails 中呈现 json 表单的错误消息

How to render error messages for a json form in Rails

本文关键字:表单 json 错误 消息 Rails      更新时间:2023-09-26

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

我在控制器中format.json { render :json => { :errors => @key.errors.full_messages }, :status => 422 }了失败的表单提交,如下所示。但是我不知道该拥有什么JS或咖啡脚本,因此会显示错误消息。

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

新.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.咖啡

# No idea what is needed in here

我已经阅读了我能找到的所有帖子,看看category_item_key.coffee需要做什么,但它们都是3-5岁的,只是不起作用。我确定它没有那么复杂,但我对 JS 了解不多,无法让它工作。

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' %>