初心者でも迷わない条件分岐の書き方・考え方・演算子の使い方
「この条件のときだけ実行したい」「Aならこう、Bならこう、どれでもなければこう」——そんな“判断”をコードに与えるのがif文です。
本記事では、if / else if / elseの基本から、つまずきやすい比較演算子・論理演算子まで、実務でそのまま使える形で丁寧に解説します。
サンプルはすべてコピペOK。最後にベストプラクティスやよくあるミスのチェック表も付けました。
目次
1. if / else if / else の基本
構文テンプレート
if (条件1) {
// 条件1がtrueのとき実行
} else if (条件2) {
// 条件1がfalse かつ 条件2がtrueのとき実行
} else {
// どれにも当てはまらないとき実行(省略可)
}
最小例
const score = 78;
if (score >= 80) {
console.log("合格(優)");
} else if (score >= 60) {
console.log("合格");
} else {
console.log("不合格");
}
ポイント
- 上から順に評価され、最初にtrueになったブロックだけが実行されます。
else if
は必要なだけ連ねられます。else
は最後の受け皿。想定外の入力に備えて置いておくと堅牢です。
2. 条件式を正しく書くための「演算子」入門
条件式は比較演算子と論理演算子で組み立てます。ベースとなる算術演算子もあわせて整理しておきましょう。
2-1. 算術(基本)演算子一覧
演算子 | 例 | 意味・結果 |
---|---|---|
+ | 3 + 2 | 足し算(文字列と足すと連結) |
- | 5 - 1 | 引き算 |
* | 4 * 2 | 掛け算 |
/ | 9 / 3 | 割り算 |
% | 10 % 3 | 余り(10÷3の余り=1) |
** | 2 ** 3 | べき乗(2の3乗=8) |
++ | i++ | 後置インクリメント(iを1増やす) |
-- | i-- | 後置デクリメント(iを1減らす) |
文字列結合に注意:"1" + 2 // => "12"
数値として計算したいときはNumber()
やparseInt()
で明示的に変換しましょう。
2-2. 比較演算子(条件の“大小・等しさ”)
演算子 | 例 | true になる条件 |
---|---|---|
=== | a === b | 値 かつ 型が等しい |
!== | a !== b | 値 または 型が異なる |
> | a > b | aがbより大きい |
>= | a >= b | aがb以上 |
< | a < b | aがbより小さい |
<= | a <= b | aがb以下 |
超重要:===
を使う
- JavaScriptには「厳密等価」
===
と「抽象等価」==
があります。 ==
は型を暗黙変換して比較するため、意図しないtrueが生まれます。
例:0 == false // true
、"" == 0 // true
- 基本は常に
===
/!==
を使うのが実務の定石です。
2-3. 論理演算子(条件を“つなぐ”)
演算子 | 例 | 意味 | |
---|---|---|---|
&& | A && B | A かつ B(両方trueでtrue) | 論理積 |
|| | A || B | A or(または) B | 論理和 |
! | !A | 否定(Aがtrueならfalse) | 論理否定 |
例:会員割引の条件
const isMember = true;
const hasCoupon = false;
if (isMember || hasCoupon) {
console.log("割引適用");
} else {
console.log("通常価格");
}
created by Rinker
¥2,750
(2025/09/22 11:01:09時点 楽天市場調べ-詳細)
3. 真偽値と「truthy / falsy」を理解する
if文は真偽値(true/false)で分岐します。
ただし、JavaScriptでは「真偽値以外」も条件式に書け、内部で真偽に解釈されます。
よく出る falsy 値(条件式でfalseとみなされる)
値 | 例 |
---|---|
false | false |
0 / -0 / 0n | 0 , 0n (BigInt) |
空文字 | "" , '' , ““ |
null | 値がない |
undefined | 未定義 |
NaN | 数でない(Not-a-Number) |
注意:NaNの罠
NaN === NaN // false
です。NaN判定は Number.isNaN(value)
を使いましょう。
4. 具体例で理解を深める
4-1. 基本的な多段分岐
function grade(score) {
if (score >= 90) return "S";
else if (score >= 80) return "A";
else if (score >= 70) return "B";
else if (score >= 60) return "C";
else return "D";
}
console.log(grade(85)); // "A"
設計ポイント
- 範囲が重ならないよう大きい条件から順に書くと安全。
- 早期
return
(ガード節)でネストを浅く保つと読みやすい。
4-2. 論理演算子で条件を組み合わせる
const age = 25;
const hasID = true;
if (age >= 20 && hasID) {
console.log("入場可");
} else {
console.log("入場不可");
}
5. if文の書き方を整えるベストプラクティス
- 厳密等価
===
を使う(==
は極力使わない) - 肯定形で書く:
if (isActive) { ... }
の方がif (!isInactive)
より読みやすい - 早期return(ガード節)でネストを浅く
function login(user) { if (!user) return "ユーザーなし"; if (!user.email) return "メール未登録"; // ここに本処理... }
- 条件を関数名で意味づけ
const isAdult = (age) => age >= 18; if (isAdult(user.age)) { ... }
- 範囲条件は順序を意識(上から厳しい/広い順に並べる)
- switchとの使い分け:値の一致が中心(例:曜日や状態定数)なら
switch
も検討
6. よくあるミスと対策(チェック表)
ミス | 例 | 問題点 | 対策 |
---|---|---|---|
= と === を混同 | if (x = 1) {} | = は代入。常に1が入って意図せずtrueに | 比較は === を使う |
== による型変換罠 | "" == 0 // true | 予期せぬtrue/false | 常に === / !== |
falsyの誤解 | if (value) {} | 0 や "" もfalse扱い | 必要なら ?? を使用 |
範囲の重複 | if (x>=80) ... else if(x>=70) ... | 70〜79が2回判定されるケース | 上から広い/厳しい順に設計 |
NaN判定 | if (x === NaN) | 常にfalse | Number.isNaN(x) |
ネストが深い | if (...) { if (...) { ... }} | 可読性低下 | 早期return・関数化 |
デイトラのWeb制作コースでJavaScriptも習える!
Web制作コース7. 実践ミニレシピ
7-1. 時間帯で挨拶を出し分け
function greetByHour(hour) {
if (hour < 0 || hour > 23) return "時刻が不正です";
if (hour < 5) return "おやすみなさい";
if (hour < 12) return "おはようございます";
if (hour < 18) return "こんにちは";
return "こんばんは";
}
7-2. フォーム入力のバリデーション
function validateSignup({ email, password }) {
if (!email || !password) return "必須項目が未入力です";
if (!email.includes("@")) return "メール形式が不正です";
if (password.length < 8) return "パスワードは8文字以上";
return "OK";
}
7-3. 価格とクーポンの条件判定
function calcPrice(base, { isMember, couponCode }) {
let price = base;
if (isMember && price >= 1000) {
price *= 0.9; // 会員10%オフ
} else if (couponCode === "WELCOME") {
price -= 200; // 一律割引
}
return Math.max(price, 0);
}
8. まとめ:if文は「読みやすい条件設計」が命
- if / else if / elseは「上から順に最初のtrueだけ実行」。
- 条件式は**比較演算子(
===
推奨)と論理演算子(&&
,||
,!
)**で組み立てる。 - truthy/falsyの挙動を理解し、
??
でデフォルト値を安全に扱う。 - 実務では早期returnや意味のある関数名で、可読性・拡張性を高める。
##(付録)演算子の早見表(保存版)
カテゴリ | 演算子 | 読み方/用途 | 例 | 備考 |
---|---|---|---|---|
算術 | + - * / % ** | 足し/引き/掛け/割り/余り/べき乗 | a ** 2 | 文字列に+ は連結 |
インクリメント | ++ -- | 1増/1減 | i++ | 前置・後置で評価順が違う |
比較 | === !== > >= < <= | 厳密等価/不等価/大小 | a === b | == は避ける |
論理 | `&& | !` | かつ/または/否定 | |
代入拡張 | += -= *= /= %= **= | 合成代入 | x += 3 | 可読性向上 |
Null合体 | ?? | null/undefinedだけ置換 | n ?? 0 | ` |
オプショナル連鎖 | ?. | 安全にプロパティ参照 | user?.name | undefinedを返す |
無料カウンセリングでアマギフ1000円貰える!
