🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

2449閲覧

jQueryで要素を非表示にしたい

Chandler_Bing

総合スコア673

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2021/02/08 01:01

お疲れ様です。

質問連投すみません。

現在以下のような簡易入力フォームを作成しています。

★簡易入力フォーム★

①ページを読み込む
②CSSでエラーメッセージ表示域を非表示
③入力値を受け付ける
④エラーがあれば、そのメッセージをエラーメッセージ表示域に表示
⑤エラーがなければ、登録完了画面へ遷移

バリデートはコントローラーを使わず、jQueryのみで行います。
現状は、一度画面にエラーメッセージを表示すると、再度入力し値が正常だとしてもメッセージが残ったままなので、バリデートを行う直前にエラーメッセージ表示域を全て非表示にする処理を追加しました。(※ページを読み込んだのと同じ状態)

追加した処理は、jsに記載の「ここが問題のソース」のソースです。
これを追加したせいで、エラーメッセージが一斉表示されなくなってしまいました。

$('.display-none').hide();はccsに記載のソースと同じことを行っている認識だったのですが、違うのでしょうか。

html

1<!--氏名--> 2<div class='row'> 3 <div class='col-md-3'> 4 <label class='control-label' for='member-name'>氏名<span class='text-danger'>(必須)</span></label> 5 </div> 6 <div class='col-md-9'> 7 <input name='member-name' id='member-name' class='form-control input-md' type='text'> 8 <p class='display-none error-member-name text-danger'></p><!--エラーメッセージ表示域--> 9 </div> 10</div> 11<!--メールアドレス--> 12<div class='row'> 13 <div class='col-md-3'> 14 <label class='control-label' for='mail-address'>メールアドレス<span class='text-danger'>(必須)</span></label> 15 </div> 16 <div class='col-md-9'> 17 <input name='mail-address' id='mail-address' class='form-control input-md' type='text'> 18 <p class='display-none error-mail-address text-danger'></p><!--エラーメッセージ表示域--> 19 </div> 20</div> 21<!--電話番号--> 22<div class='row'> 23 <div class='col-md-3'> 24 <label class='control-label' for='phone-number'>電話番号<span class='text-danger'>(必須)</span></label> 25 </div> 26 <div class='col-md-9'> 27 <input name='phone-number' id='phone-number' class='form-control input-md' type='text'> 28 <p class='display-none error-phone-number text-danger'></p><!--エラーメッセージ表示域--> 29 </div> 30</div>

css

1@charset "UTF-8"; 2.display-none { 3 display: none; 4}

js

1// 「登録」ボタン押下時 2$('#sign-up').on('click', function() { 3 4 // 既存エラーメッセージを非表示 5 /$('.display-none').hide();// ←ここが問題のソース 6 7 // 入力値が空、もしくは不正な値であればメッセージを表示 8 9 // 氏名 10 if ($('#member-name').val() == '') { 11 displayErrorMessage('.error-member-name', error_no_input) 12 } 13 14 // メールアドレス 15 if ($('#mail-address').val() == '') { 16 displayErrorMessage('.error-mail-address', error_no_input) 17 } else { 18 if (validateMailAddress($('#mail-address').val()) == false) { 19 displayErrorMessage('.error-mail-address', error_mail_address) 20 } 21 } 22 23 // 電話番号 24 if ($('#phone-number').val() == '') { 25 displayErrorMessage('.error-phone-number', error_no_input) 26 } else { 27 if (validatePhoneNumber($('#phone-number').val()) == false) { 28 displayErrorMessage('.error-phone-number', error_phone_number) 29 } 30 } 31 32}); 33 34// エラーメッセージ表示 35function displayErrorMessage(class_name, msg) { 36 $(class_name).text(msg) 37 $(class_name).removeClass('display-none') 38};

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

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

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

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

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

guest

回答1

0

ベストアンサー

hide() だと不整合

jQuery の hide() は、指定した要素に「style="display: none"」を足します。これは他のスタイルシートより優先度が高いので、show() で戻すかstyle属性を変更しない限り表示されなくなります。

関数 displayErrorMessage() と整合性を取るなら、hide() の代わりに addClass('display-none') とします。

$('.display-none') では選択できない

関数 displayErrorMessage()display-none クラスを外していますから、表示したエラーメッセージ要素は $('.display-none') にマッチしません。他の方法で要素を選択する必要があります。たとえば $('p.text-danger') とか。

投稿2021/02/08 01:15

編集2021/02/08 05:15
int32_t

総合スコア21679

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

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

Chandler_Bing

2021/02/08 01:32

ありがとうございます。 addClass('display-none')試してみたんですが。。。メッセージが残ったままです。 ⇒ブラウザのキャッシュの削除や、jsが更新されていることは確認しています。
int32_t

2021/02/08 03:46 編集

表示時に displa-none クラスを外しているのですから、$('.display-none') では表示中のものは取れないですね。HTMLソースを見る限りでは $('p.text-danger') でしょうか。回答に追記しておきます。
Chandler_Bing

2021/02/08 05:10

お疲れ様です。 ご提示頂いた内容($('p.danger-text').addClass('display-none');) を試したのですが。。。 やっぱり、メッセージがのこったままになります。 他にも色々と試したんですが。。。
int32_t

2021/02/08 05:16

$('p.danger-text') じゃなくて $('p.text-danger') でした。回答を修正しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問