質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

1557閲覧

バリデーションエラーが意図せず吹き出しで表示される

Ayustak

総合スコア30

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2020/08/16 13:50

編集2020/08/16 14:22

発生している問題

rails6.0.2

概ねrailsチュートリアルに沿う形でアプリの作成をしているのですが、バリデーションエラーの表示が何故かemailのみ吹き出しで表示され、他の項目は表示されません。調べたところjavascript(jquery?)の機能のようなのですが、何処を触れば良いのかが分かりませんでした。チュートリアルviewに記述した通りに表示させたいです。
何かわかる方がいましたらご教授願いたいです。

↓こんな感じです。
イメージ説明

試したこと

user.errors.full_messagesでエラーが正しく表示されることと、<%= render 'shared/error_messages' %>をコメントアウトしても発生することを確認しました。

該当のソースコード

/users_controller class UsersController < ApplicationController def show @user = User.find(params[:id]) end def new @user = User.new end def create @user = User.new(user_params) if @user.save flash[:success] = "登録成功" redirect_to @user else render 'new' end end private def user_params params.require(:user).permit(:name, :email, :password, :password_confirmation) end end
/users/new <h1>ユーザー登録</h1> <div class="form-group row"> <div class="col-md-6 col-md-offset-3"> <form>   <%= form_with(model: @user, local: true) do |f| %>   <%= render 'shared/error_messages' %>   <div class="form-group"> <%= f.label :ニックネーム %> <%= f.text_field :name, class: "form-control", placeholder: "20文字以内" %> </div> <div class="form-group"> <%= f.label :メールアドレス %> <%= f.email_field :email, class: "form-control", placeholder: "メールアドレス" %> </div> <div class="form-group"> <%= f.label :パスワード %> <%= f.password_field :password, class: "form-control", placeholder: "6文字以上" %> </div> <div class="form-group"> <%= f.label :password_confirmation, "パスワード(再入力)" %> <%= f.password_field :password_confirmation, class: "form-control", placeholder: "6文字以上" %> </div> <div class="form-group text-center"> <%= f.submit "作成する", class: "btn btn-primary w-100" %> </div> <% end %> </form> </div> </div>
/_error_messages <% if @user.errors.any? %> <div class="alert alert-danger"> The form contains <%= pluralize(@user.errors.count, "error") %>. </div> <ul> <% @user.errors.full_messages.each do |msg| %> <li><%= msg %></li> <% end %> </ul> <% end %>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

<form>タグを削除し、

<%= form_with(model: @user, local: true) do |f| %>

<%= form_with(model: @user, local: true, class: 'needs-validation', html: {novalidate: true}) do |f| %>
に変えることで解決しました。

bootstrap4の入力検証機能を有効にするneeds-validationクラスと、ブラウザのデフォルトの入力検証機能を無効にするnovalidate属性を指定してなかったことと、<form>とform_withでformタグが2つ生成されていた為に不具合が出ていたようです。

投稿2020/08/22 09:28

編集2020/08/22 23:39
Ayustak

総合スコア30

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問