javascript

【javascript】条件分岐のif文について初心者向けに徹底解説!

if文

 

今回は、javascriptの制御構文の一つである「if文」について初心者向けにやさしく解説します。

 

if文を使用することで、通常であれば上から下に処理をするプログラムを

「もし〜なら…する」という、条件によって処理を分岐させる

ことができます。

またif文には次のような使用例があります。

  • 入力フォームで必要文字数に満たない場合にメッセージを表示させる
  • エラーが起きた場合のみ特別なメッセージを表示させる

このように「if文」は、ある一定の条件を満たしたとき「別の処理」を行いたい場合に使用するとても重要な構文です。

ぜひこの記事を読んで基礎を学んでいって下さいね。

 

この記事では

if文elseを使った 単純分岐 や、else ifを使った 多岐分岐 などの基本的な使い方を、実際のコードやイラストを交えて優しく解説しています。

 

できるだけわかりやすく解説するので、ぜひ最後まで読んでみて下さいね!

目次

単純分岐elseの基本elseを使用する場合elseを使わない場合
多岐分岐else ifの基本if文のネスト

 📖目次に戻る

単純分岐 else の基本

if文は、与えられた条件式の結果が正しい 「true」または、違っている「false」 かによって処理を分岐させます。

if/else文を使った条件分岐の図解

 📖目次に戻る

elseを使用する場合

条件式の結果が「true」の場合は if()の直後のブロックの処理を実行し、「false」の場合は elseの直後のブロックの処理を実行します。

ブロックは、{ ~ } で囲まれた部分のことだよ。

 

構文

if (条件式) {

//条件式がtrueである場合に実行する処理

} else {

//条件式がfalseである場合に実行する処理

}

「条件式」とは、例えば「もし田中君が未成年なら、お酒は飲めません!」という文章があった場合の「もし田中君が未成年なら」の部分にあたります。

そして、この条件式は「演算子」と組み合わて使用することが多いです。

 

演算子は、簡単に言うと四則演算で使用されるような「+」「-」「/」「*」の記号のことだよ。

 

では早速確認してみましょう。

今回は、例として「19歳の田中君はお酒が飲めるか?」を if文を使って年齢で判定させてみます。

ポイント

未成年の場合は「お酒は飲めません!」、成人の場合は「お酒飲めます!」という文章が出力されるプログラムを用意しています。

条件式には「未成年か成人か」を年齢で判別する「age < 20」を設定しています。

 </>javascript

let age = 19; document.write( '田中君は、' );

if (age < 20) {

document.write( 'お酒は飲めません!' ); //こちらが表示されます。

} else {

document.write( 'お酒飲めます!' );

}

if文のelseを使った出力結果

「田中君は、お酒は飲めません!」と怒られてしまいましたね。

これは最初の「let age = 19;」で田中君の年齢を19歳に設定しているため、条件式( age < 20 )でtrueとなり、直後のブロック{} の中のプログラムが実行されているためです。

 

ちなみに、最初の age に「20」以上の数字を代入すると「田中君は、お酒飲めます!」と表示されるよ。

 📖目次に戻る

elseを使わない場合

実は「else」を使用せず、「if」のみを使用して条件分岐させることも可能です。

これは、ある条件に合致したときのみ処理を実行する書き方です。

 

それでは、前項で使用した式をelseを使わない式に書き換えてみましょう。

 </>javascript

let age = 19;

if ( age < 20 ) {

document.write( '田中君は、お酒は飲めません!' );

} 

if文のelseを使った出力結果

先ほどと同じ結果が表示されましたね。

もし最初の age に「20」以上の数字を代入した場合は、if文より下の処理が通常通り実行されます。

 

あくまで、特定の条件に合致したときだけ何か処理をしたい場合に使えるテクニックだね。

 📖目次に戻る

多岐分岐 else if の基本

前項では「if」「else」を使って、処理をtrueの場合とfalseの場合の2つに分岐させましたが、

「else if」を使うことで、さらに分岐の条件を指定して、多岐分岐させることができます。

if ~ else if文を使った条件分岐の図解

「もし〜なら...を、それとも○○なら△△をいずれでもなければ××を」という表現が可能になります。

なんだかしつこい奴みたいですね。

構文

if (条件式1) {

 //条件式1がtrueである場合に実行

} else if(条件式2) {

 //条件式2がtrueである場合に実行

...

} else {

 //いずれもfalseである場合に実行

}

「else if」は必要に応じて、分岐の数だけ使用することができるよ。

 

では、実際に確認してみましょう。

今度は、「75点を取った田中君のテストの評価」をelse if文を使って点数分岐させてみます。

ポイント

田中君の点数によって、

90点以上は「大変良くできました!!」

70点以上は「良くできました!!」

60点以上は「まぁまぁ良くできました!」

59点以下は「不合格です。」

と表示されるプログラムを用意しています。

 </>javascript

let score = 75; document.write( '田中君は、' );

if (score >= 90) {

document.write( '大変良くできました!!' );

} else if(score >=70) {

document.write( '良くできました!' ); //こちらが表示されます。

} else if(score >=60) {

document.write( 'まぁまぁ良くできました!' );

} else { document.write( '不合格です。' );

}

if ~ else if文の出力結果

田中君の点数は75点なので、最初の条件式(score >= 90)はfalseとなり、直後の(score >=70)の処理が実行されました。

 

しかしここで、以下の点に注意する必要があります。

複数の条件式がtrueでも、実行される処理は最初にtrueとなった1ブロックのみ

 

それでは、今度は田中君が「100点」を取った場合の例で見てみましょう。

 </>javascript

let score = 100; document.write( '田中君は、' );

if (score >= 90) {

document.write( '大変良くできました!!' ); //こちらが表示されます。

} else if(score >=70) {

document.write( '良くできました!' );

} else if(score >=60) {

document.write( 'まぁまぁ良くできました!' );

} else {

document.write( '不合格です。' );

}

if ~ else if文の出力結果 その2

結果は、90点以上なので最初の条件式(tanaka >= 90)でtrueとなり、「大変良くできました!!」が表示されます。

ですが、70点以上でもあるので、次の条件式(tanaka >=70)もtrueで「良くできました!」「まぁまぁ良くできました!」と、さらに2回褒められても良さそうですよね。

 

しかし、最初にtrueとなった時点でif文の外から処理が開始するため、それ以降の条件式は判定すらされない点に注意して下さい。

 

else ifを使って条件式を複数指定するときは順番に気をつけようね。

 📖目次に戻る

if文のネスト

if文は、if文の中にif文記述して「入れ子構造」にすることもできます。

この入れ子構造のことをネストと呼びます。

if文のネストの図解

では、先ほどのif文をネスト構造に書き換えてみましょう。

前項で、田中君はせっかく100点を取ったので、100点を取った時だけ特別なメッセージが出るようにしてみます。

 </>javascript

let score = 100; document.write( '田中君は、' );

if ( score >= 90) {

document.write('大変良くできました!!'); //こちらが表示されます。

    if ( score === 100) {

        document.write( '満点おめでとう!!' ); //こちらも表示されます。

      } 

} else if( score >=70) {

document.write( '良くできました!' );

} else if(score >=60) {

document.write( 'まぁまぁ良くできました!' );

} else {

document.write( '不合格です。' );

}

(score >= 90) がtrueなので「大変良くできました!!」が表示されるのはもちろん、

同じブロック内にある条件式(score === 100) もtrueとなり、追加で「満点おめでとう!!」というメッセージが表示されます。

 

ネストの深さに制限はないけど、あまり深い構造にすることは望ましくないよ。

📖目次に戻る

最後に

いかがでしたでしょうか、今回はjavascriptの基本である制御構文の「if文」について解説しました。

もっと詳しく学習したい方は、下の記事一覧から他の記事もご覧下さい。

Javascript

 

続きを見る

最後までお読みいただき、ありがとうございました!

-javascript
-