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

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

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

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

jQuery

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

Q&A

解決済

1回答

2348閲覧

jQueryのerror-flag?について

kenj

総合スコア29

if

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

jQuery

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

0グッド

0クリップ

投稿2017/09/07 16:22

初めまして。初心者ですが宜しくお願い致します。
現在下記のようなお問い合わせフォームを作るコードを見ているのですが、
どうしても「error-flag」の存在の意味が分からないでいます。
このフラグが無くてもifとelseだけで文章としては成立しているような気が
するのですが、、このerror-flagがある事で文章にどのような意味が
出てくるのか、また最後のreturn falseの意味も教えて頂けましたら幸いです。
初歩的な質問ですみませんが、宜しくお願い致します。

$('.contact-form form').submit(function(){ var error_flag = false; $(this).children('input, textarea').each(function(){ var body = $(this).val(); if (!body) { $(this).prev('.error-message').text('入力してください'); error_flag = true; } else { $(this).prev('.error-message').text(''); } }); if (!error_flag) { $('.contact-form').html('<h4>お問い合わせありがとうございます。</h4>'); } return false; }); }); コード

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

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

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

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

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

guest

回答1

0

ベストアンサー

まず、error_flag の件ですが、このコードでは、submit ボタンが押されたとき、そのフォーム内の inputtextarea をひとつずつ調べ、値が空でないかチェックしています。each() の中で個々の入力値をチェックしているわけですね。
で、このループを抜けたあと、error_flag を見ていますが、これは先のループ内でひとつでも空のものがあれば true になっています。逆に言えば、すべての inputtextarea にちゃんと入力がなされていたときにだけ false になります。

整理すると、if (!body) { のところで調べているのは個々の入力値、if (!error_falg) { のところで調べているのはフォーム全体として入力がちゃんとされていたか、ということです。

次に return false; についてです。イベントハンドラの中で false を返すと、デフォルトのイベントをキャンセルし、それ以上のイベントの伝搬をさせません。簡単に言えば、ここで return false; しないと submit のデフォルトの動作、すなわち、フォームの送信が行なわれますが、return false; していることによりフォーム送信は行われません。

投稿2017/09/07 16:43

unau

総合スコア2468

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

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

kenj

2017/09/07 17:13

丁寧なご回答ありがとうございました。 部分ごとの分かり易いご説明のおかげでフラグの意味も分かりました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問