私はFormstaticと一緒にBootstrap-Sassを使用しています。この写真のように、Formstaticを使用してフィールドの横にエラーメッセージが自動的に表示されるはずだと思いました:(出典:asciicasts.com)
しかし、ユーザーが無効な入力を行っても、私のアプリはエラーメッセージを表示しません。これは簡単な問題のようですが、背後にある理由を理解することはできません。
PostController
# POST /posts
# POST /posts.json
def create
@post = Post.new(params[:post])
@post.view = 0
@post.like = 0
@post.hate = 0
respond_to do |format|
if @post.save
@posts = Post.paginate(:page => params[:page], order: 'like desc', per_page: 10)
format.html { redirect_to posts_path }
format.json { render json: @post, status: :created, location: @post }
else
format.html { render action: "new" }
format.json { render json: @post.errors, status: :unprocessable_entity }
end
end
end
PostModel
validates :name, :presence => true
validates :content, :presence => true,
:length => { :minimum => 10, :maximum => 300}
_form(投稿)
<% @post = Post.new %>
<%= semantic_form_for @post do |f| %>
<%= f.semantic_errors :name %>
<%= f.inputs do %>
<%= f.input :name, :label => 'name' %>
<%= f.input :content, :label => 'body' %>
<% end %>
<%= f.actions do %>
<%= f.action :submit, :button_html => { :class => "btn btn-primary" }, :as => :button %>
<%= f.action :cancel, :as => :link %>
<% end %>
PostControllerで、次の2行を削除してみました
#format.html { render action: "new" }
#format.json { render json: @post.errors, status: :unprocessable_entity }
と追加
render @post.errors
それから、私は得ました
@messages={:name=>["can't be blank"], :content=>["can't be blank", "is too short (minimum is 10 characters)"]}>
したがって、問題は、jsonのレンダリング方法が間違っている可能性があると思います。誰かがそれを修正する方法を教えてもらえますか?