我正在尝试在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的了解并不多。
答案 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' %>