JavaScript if文 条件分岐を行うサンプル

目次

if文とは

if文の構造とサンプル

条件がtrueの時のみ処理します。falseでは処理しません。

if (条件){
   処理
}

コード

<script>
    const a = 1;

    if (a === 1) {
        console.log("test1"); // test1が出力される
    }
</script>

4行目は、aの値は1なのでtrueとなり5行目が実行されます。

point

・条件が合致することをtrue(真)といいます。
・条件が合致しないことをfalse(偽)といいます。
・条件が合致する場合、配下のブロック{ }の処理が実行され、if文の処理は終了します。
・条件が合致しない場合、配下のブロック{ }の処理は実行されず、if文の処理は終了します。
・4行目の===は比較演算子です。

 

ifとelseの構造とサンプル

条件がtrueの時は、trueの処理をします。falseの時は、falseの処理をします。

if (条件){
   処理1
}else{
   処理2
}

コード

<script>
    const a = 2;

    if (a === 1) {
        console.log("test1");
    } else {
        console.log("test2"); // test2が出力される
    }
</script>

4行目は、aの値は2なのでfalseとなり7行目が実行されます。

 

ifとelse ifとelseの構造とサンプル

複数の条件で処理を分けたい場合に使用します。elseは条件にあてはまらない場合に処理されます。

if (条件1){
   処理1
} else if (条件2) {
   処理2
} else {
  処理3
}

コード

<script>
    const a = 2;

    if (a === 1) {
        console.log("test1");
    } else if (a === 2) {
        console.log("test2"); // test2が出力される
    } else {
        console.log("test3");
    }
</script>

4行目は、aの値は2なのでfalseとなり次の分岐の6行目へ進みます。
6行目は、aの値は2なのでtrueとなり、7行目が実行されます。
if文は終了となり11行目に進みます。

point

・else ifは、1つ以上記述できます。
・elseは、1つのみ記述できます、または省略可能です。
・else ifが多くなるときはswitch文の使用を検討します。
JavaScript switch文のサンプル

 

if文の中にif文がある構造とサンプル

if文の中にif文の記述は可能です。

if (条件1){
  if (条件2){
   処理
  }
}

コード

<script>
    const a = 1;
    const b = 1;

    if (a === 1) {
        if (b === 1) {
            console.log("test1"); // test1が表示される
        }
    }
</script>

5行目は、aの値は1なのでtrueとなり6行目が実行されます。
6行目は、bの値は1なのでtrueとなり7行目が実行されます。

point

・ネストの構造、入れ子ともいいます。

 

比較演算子

比較演算子は、2つの値を比べて条件を満たしていればtrue,そうでない場合はfalseを返します。
イコール3つ(===)は値と型を比較します。

比較演算子 説明
a == b aとbの値は等しい
a === b aとbの値は等しい かつ 型も等しい
a != b aとbの値は等しくない
a !== b aとbの値が等しくない または 型が等しくない
a > b aはbより大きい
a >= b aはbより大きい または 等しい
a < b aはbより小さい
a <= b aはbより小さい または 等しい

JavaScript if文の == と === の違い

 

論理積(&&)  AかつB

<script>
  const a = 2;
  const b = 2;

  if (a === 2 && b === 2) {
    console.log("true"); // true 表示される
  }
</script>

5行目は、左の式と右の式が共にtrueなので、trueになります。

point

if (左の条件式) && (右の条件式)
  • 左の式と右の式が両方ともtrueの場合、trueになります。それ以外はfalseです。
  • 左の式がfalseの場合、右の式は判定(評価)されません。これを短絡評価(ショートサーキット評価 : Short-Circuit Evaluation)といいます。

 

論理和(||)  AまたはB

<script>
  const a = 1;
  const b = 2;

  if (a === 2 || b === 2) {
    console.log("true"); // true 表示される
  }
</script>

5行目は、左の式はfalseですが右の式がtrueなのでtrueになります。

point

if (左の条件式) || (右の条件式)
  • 左の式または右の式のどちらかがtrueの場合、trueになります。
  • 左の式がtrueの場合、右の式は判定(評価)されません。これを短絡評価(ショートサーキット評価 : Short-Circuit Evaluation)といいます。

 

論理否定(!)  Aではない

<script>
    const a = 1;

    if (!(a === 2)) {
        console.log("true"); // trueが表示される
    }

    if (!(a === 1)) {
        console.log("true");
        
    } else {
        console.log("false"); // falseが表示される
    }
</script>

4行目は値の比較でfalseになり、それを!で否定するのでtrueになります。
8行目は値の比較でtrueになり、それを!で否定するのでfalseになります。

point

if  !(条件式) 
  • 式がfalseの場合にtrueになります。
  • 式がtrueの場合にfalseになります。

 

排他的論理和(^)

<script>
    const a = 2;
    const b = 2;

    if ((a === 2) ^ (b === 3)) {
        console.log("true"); // trueが表示される
    } else {
        console.log("false");
    }

    if ((a === 3) ^ (b === 2)) {
        console.log("true"); // trueが表示される
    } else {
        console.log("false");
    }

    if ((a === 2) ^ (b === 2)) {
        console.log("true");
    } else {
        console.log("false"); // falseが表示される
    }

    if ((a === 3) ^ (b === 3)) {
        console.log("true");
    } else {
        console.log("false"); // falseが表示される
    }
</script>

5行目は、左の式がtrueで右の式がfalseなので、trueになります。
11行目は、左の式がfalseで右の式がtrueなので、trueになります。
17行目は、左の式と右の式が両方ともtrueなので、falseになります。
23行目は、左の式と右の式が両方ともfalseなので、falseになります。

point

if (左の条件式) ^ (右の条件式)
  • 左の式がtrueで右の式がfalseの場合、trueになります。
  • 左の式がfalseで右の式がtrueの場合、trueになります。
  • 左の式と右の式が両方ともtrueの場合、falseになります。
  • 左の式と右の式が両方ともfalseの場合、falseになります。

 

値が代入されているか(undefined)

<script>
    let a; //constの場合、値の代入がないとエラー

    if (typeof a === "undefined") {
        console.log("true"); // true 出力される
    }

    if (a) {
        console.log("true");
    } else {
        console.log("false"); // false 出力される
    }

    const b = 3;

    if (b) {
        console.log("true"); // true 出力される
    }
</script>

4行目は、typeof演算子でundefinedか比較しています。
8,16行目のように、変数のみでの判定もできます。

point

if (typeof 変数 === "undefined") 
  • undefinedは変数に値が代入されていない状態を表します。
  • undefinedを比較するときは、typeof演算子を使用します。

 

nullを比較

<script>
  const a = null;
  
  if (a === null) {
    console.log("true"); // true 出力される
  }
  
  if (a) {
    console.log("true");
  } else {
    console.log("false"); // false 出力される
  }

  if (a === "") {
    console.log("true");
  } else {
    console.log("false"); // false 出力される
  }
</script>

point

if (変数 === null) 

nullは中身が空の状態を表します。nullと空文字("")は別です。

 

空文字を比較

<script>
  const c = "";
  
  if (c === "") {
    console.log("true"); // true 出力される
  }

  if (c) {
    console.log("true");
  } else {
    console.log("false"); // false 出力される
  }

  if (c === null) {
    console.log("true");
  } else {
    console.log("false"); // false 出力される
  }
</script>

point

nullと空文字("")は別です。

 

三項演算子

<script>
    const a = 1;

    // 三項演算子
    const b = a === 0 ? "true" : "false";
    console.log(b); // falseが表示される

    if (a === 0) {
        console.log("true");
    } else {
        console.log("false"); // falseが表示される
    }
</script>

5行目は、三項演算子です。
5,6行目をif文で書くと、8~12行目のようになります。

point

変数 = 条件式  ?  値1 : 値2
  • 条件式がtrueのとき、値1を返します。
  • 条件式がfalseのとき、値2を返します。

関連の記事

JavaScript if文の == と === の違い
JavaScript if文で配列を比較するサンプル

△上に戻る