前提・実現したいこと
新規登録のフォームを作成しており、
その際、必須項目が空や半角だった場合、
'Full-width characters'のような
エラーメッセージを表示させたい
発生している問題・エラーメッセージ
新規登録のページが更新されるだけで 'Full-width characters'のような エラーメッセージを表示されない
該当のソースコード
model.user.rb
class User < ApplicationRecord # Include default devise modules. Others available are: # :confirmable, :lockable, :timeoutable, :trackable and :omniauthable devise :database_authenticatable, :registerable, :recoverable, :rememberable, :validatable validates :nickname,:email,:birthday, presence: true validates :last_name, presence: true, presence: {message: 'last name cant be black'} validates :first_name, presence: true, presence: {message: 'first name cant be black'} validates :last_name_kana, presence: true, presence: {message: 'last name kana cant be black'} validates :first_name_kana, presence: true, presence: {message: 'first name kana cant be black'} validates :email, uniqueness: true validates :first_name, :last_name, :first_name_kana, :last_name_kana, format: {with: /[^ -~。-゚]+/,message: 'Full-width characters'} end
registrations/new.html.erb
<%= render "shared/second-header"%> <%# 「モデル名」にはUserモデルであれば@userを渡しましょう。「新規登録機能へのパス」は、devise導入後にrails routesを実行してdevise/registrations#createへのパスを確認し、記載してください。 %> <%= form_with model:@user, url: user_registration_path, class: 'registration-main', local: true do |f| %> <%# //「モデル名」にはUserモデルであれば@userを渡しましょう。「新規登録機能へのパス」は、devise導入後にrails routesを実行してdevise/registrations#createへのパスを確認し、記載してください。 %> <div class='form-wrap'> <div class='form-header'> <h1 class='form-header-text'> 会員情報入力 </h1> </div> <% render 'shared/error_messages', model:f.object %> **←ここの部分で _error_messages.html.erbを読み込む** <div class="form-group"> <div class='form-text-wrap'> <label class="form-text">ニックネーム</label> <span class="indispensable">必須</span> </div> <%= f.text_area :nickname, class:"input-default", id:"nickname", placeholder:"例) furima太郎", maxlength:"40" %> </div> <div class="form-group"> <div class='form-text-wrap'> <label class="form-text">メールアドレス</label> <span class="indispensable">必須</span> </div> <%= f.email_field :email, class:"input-default", id:"email", placeholder:"PC・携帯どちらでも可", autofocus: true %> </div> <div class="form-group"> <div class='form-text-wrap'> <label class="form-text">パスワード</label> <span class="indispensable">必須</span> </div> <%= f.password_field :password, class:"input-default", id:"password", placeholder:"6文字以上の半角英数字" %> <p class='info-text'>※英字と数字の両方を含めて設定してください</p> </div> <div class="form-group"> <div class='form-text-wrap'> <label class="form-text">パスワード(確認)</label> <span class="indispensable">必須</span> </div> <%= f.password_field :password, class:"input-default", id:"password-confirmation", placeholder:"同じパスワードを入力して下さい" %> </div> <div class="form-group"> <p class='form-info-header'> 本人確認 </p> <p class='form-info-text'> 安心・安全にご利用いただくために、お客さまの本人情報の登録にご協力ください。他のお客さまに公開されることはありません。 </p> </div> <div class="form-group"> <div class='form-text-wrap'> <label class="form-text">お名前(全角)</label> <span class="indispensable">必須</span> </div> <div class='input-name-wrap'> <%= f.text_area :last_name, class:"input-name", id:"last-name", placeholder:"例) 山田" %> <%= f.text_area :first_name, class:"input-name", id:"first-name", placeholder:"例) 陸太郎" %> </div> </div> <div class="form-group"> <div class='form-text-wrap'> <label class="form-text">お名前カナ(全角)</label> <span class="indispensable">必須</span> </div> <div class='input-name-wrap'> <%= f.text_area :last_name_kana, class:"input-name", id:"last-name-kana", placeholder:"例) ヤマダ" %> <%= f.text_area :first_name_kana, class:"input-name", id:"first-name-kana", placeholder:"例) リクタロウ" %> </div> </div> <div class="form-group"> <div class='form-text-wrap'> <label class="form-text">生年月日</label> <span class="indispensable">必須</span> </div> <div class='input-birth-wrap'> <%= raw sprintf( f.date_select( :birthday, class:'select-birth', id:"birth-date", use_month_numbers: true, prompt:'--', start_year: 1930, end_year: (Time.now.year - 5), date_separator: '%s'), "<p> 年 </p>", "<p> 月 </p>") + "<p> 日 </p>" %> </div> <p class='info-text'>※ 本人情報は正しく入力してください。会員登録後、修正するにはお時間を頂く場合があります。</p> </div> <div class="form-group"> <h2 class='form-bottom-text'> 「会員登録」のボタンを押すことにより、 <span>利用規約</span> <br>に同意したものとみなします </h2> </div> <div class='register-btn'> <%= f.submit "会員登録" ,class:"register-red-btn" %> </div> <p class='register-info'>本人情報の登録について</p> </div> <% end %> <%= render "shared/second-footer"%>
shared/_error_messages/html.erb
<% if model.errors.any? %> <div class="error-alert"> <ul> <% model.errors.full_messages.each do |message| %> <li class='error-message'><%= message %></li> <% end %> </ul> </div> <% end %>
試したこと
ページのリンク先を違うと思い、
_error_messages/html.erbを別のフォルダに移動させたりしたが、
別のエラーが出たので、最初のフォルダに戻した
またエラーメッセージを日本語に変えてみたが、
エラーメッセージは表示されなかった
補足情報(FW/ツールのバージョンなど)
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。