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

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

新規登録して質問してみよう
ただいま回答率
85.46%
if

if文とは様々なプログラミング言語で使用される制御構文の一種であり、条件によって処理の流れを制御します。

jQuery

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

Q&A

1回答

929閲覧

jQueryを使ったフォームの実装で、項目のいずれかが未記入の場合「ボタン(submit)を無効化」、全て満たすと「ボタンを有効化、色を変える」という風にしたいのですが、うまくできません。

退会済みユーザー

退会済みユーザー

総合スコア0

if

if文とは様々なプログラミング言語で使用される制御構文の一種であり、条件によって処理の流れを制御します。

jQuery

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

0グッド

0クリップ

投稿2021/11/29 02:54

編集2021/11/29 02:55

具体的に詰まっている部分として、if文を作り、「submitを無効化」は実装できたのですが、「ボタンの色」に関しては、項目の全てではなくどれか一つが埋まっただけで色が変わってしまいます。
if文はそれぞれを「&&」で括り、色の変化に関してはaddClassを使っています。

入力するそれぞれの項目は
"名前"
"メールアドレス"
"お問い合わせ内容"
"「同意するか」のチェックボックス"
それぞれのHTMLに「disabled」を記入してます。

最後に「送信ボタン(submitBtn)」です。

該当のソースコード

var $submitBtn = $('#js_submit') $('#form input,#form textarea').on('change', function () { if ( $('#form input[type="text"]').val() !== "" && $('#form input[type="email"]').val() !== "" && $('#form textarea[name="detail"]').val() !== "" && $('#form input[type="checkbox"]').val() !== "" && $('#form #privacyCheck').prop('checked') === true ) { $submitBtn.prop('disabled', false); } else { $submitBtn.prop('disabled', true); $submitBtn.addClass('el_btn'); } });

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

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

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

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

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

m.ts10806

2021/11/29 02:56

htmlも提示されないとこちらで再現できませんしなんとも言えません。
guest

回答1

0

Get the current value of the first element in the set of matched elements.

.val() | jQuery API Documentation

とのことですから、$('#form input[type="text"]').val()は全てのテキスト入力フォームの値を取得するわけではないです。

投稿2021/11/29 03:04

Lhankor_Mhy

総合スコア36163

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問