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

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

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

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

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

Q&A

解決済

1回答

869閲覧

RailsTutorial/アレンジしたコードでエラーメッセージを出したい

amedama

総合スコア37

Ruby on Rails 5

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

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Bootstrap

BootstrapはウェブサイトデザインやUIのWebアプリケーションを素早く 作成する可能なCSSフレームワークです。 Twitter風のデザインを作成することができます。

0グッド

0クリップ

投稿2019/04/22 12:48

編集2019/04/22 13:00

アクセスいただきありがとうございます。
私は独学でプログラミングを学んでおります。
現在、Rails tutorialをBootstrap4&RSpecを利用し、アレンジしたコードを書いて勉強しています。

ユーザー登録機能を実装している最中なのですが、
登録失敗時のエラーメッセージが出ません。

公式で書かれたコードは↓です。

<% provide(:title, 'Sign up') %> <h1>Sign up</h1> <div class="row"> <div class="col-md-6 col-md-offset-3"> <%= form_for(@user) do |f| %> <%= render 'shared/error_messages' %> <%= f.label :name %> <%= f.text_field :name, class: 'form-control' %> <%= f.label :email %> <%= f.email_field :email, class: 'form-control' %> <%= f.label :password %> <%= f.password_field :password, class: 'form-control' %> <%= f.label :password_confirmation, "Confirmation" %> <%= f.password_field :password_confirmation, class: 'form-control' %> <%= f.submit "Create my account", class: "btn btn-primary" %> <% end %> </div> </div>

自分がアレンジして、form_withを使ったコードが↓です。

<% provide(:title, 'SignUp') %> <h1>Sign up</h1> <div class="row"> <div class="col-md-6 offset-md-3"> <%= form_with model: @user do |f| %> <%= render 'shared/error_messages' %> <%= f.label :name %> <%= f.text_field :name, class: 'form-control' %> <%= f.label :email %> <%= f.email_field :email, class: 'form-control' %> <%= f.label :password %> <%= f.password_field :password, class: 'form-control' %> <%= f.label :password_confirmation, "Confirmation" %> <%= f.password_field :password_confirmation, class: 'form-control' %> <%= f.submit "Create my account.", class:"btn btn-primary"%> <% end %> </div> </div>

変更後、ブラウザで実際にユーザー登録をしました。
成功時の処理は上手くいきましたが、失敗時出るはずのパーシャルのエラー文が出ません。

出るはずのパーシャルのコードは以下です。

<% if @user.errors.any? %> <div id="error_explanation"> <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> </div> <% end %>

登録失敗時のサーバーのログを見ると、

Rendered shared/_error_messages.html.erb (0.6ms)

となっており、パーシャル自体はちゃんと挿入され、表示されているようですが、思ったように表示されていません。

試しにパーシャルに

<%= @user.name %>

を追加してみましたが、@user.nameは出力されませんでした。

以上から、自分なりの分析では@userが上手くパーシャルに伝わってない、form_withの使い方が間違っている(うまく言語化でいませんが、、、)のだと思っています。

ちなみにコントローラーは以下です。

class UsersController < ApplicationController def new @user = User.new end def show @user = User.find(params[:id]) end def create @user = User.new(user_params) if @user.save flash[:success] = "Welcome to the Sample App!" redirect_to @user else render 'new' end end private def user_params params.require(:user).permit(:name, :email, :password,:password_confirmation) end end

どなたかご教授よろしくお願いします。
また、他に必要な情報があれば記載しますので、ご助言よろしくお願います。

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

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

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

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

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

guest

回答1

0

自己解決

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

に変更すれば、期待通りの動作になりました。
form_withはデフォルトで非同期通信になることは知っていましたが、それに合わせたjavascriptを書かなければいけないことに気づいていませんでした。

投稿2019/04/22 13:59

amedama

総合スコア37

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問