【JS応用】’if..else’ を ‘?’ で書き直します

三項演算子による条件分岐の最適化:コードの可読性と保守性を高める戦略

現代のフロントエンド開発において、コードの「表現力」は品質を決定づける重要な要素です。特にJavaScriptやTypeScriptにおける条件分岐は、アプリケーションのロジックを構成する基礎ですが、`if..else`文を多用しすぎると、コードが縦に長く伸び、いわゆる「スパゲッティコード」の温床になりがちです。

本記事では、条件演算子(三項演算子)を駆使してコードを簡潔かつ宣言的に記述するためのベストプラクティスを解説します。単なる構文の置き換えにとどまらず、実務レベルでの判断基準や、可読性を損なわないための設計思想にまで踏み込みます。

三項演算子の基本構造と設計思想

三項演算子は、`条件式 ? 真の場合の式 : 偽の場合の式` という構文を持ちます。これは単なる「if文の省略形」ではなく、「値を評価して代入する」という関数型プログラミング的なアプローチに適合したツールです。

`if..else`文が「手続き型(どうやって処理を実行するか)」の記述であるのに対し、三項演算子は「宣言的(何の結果を得たいか)」な記述に適しています。Reactのようなコンポーネント指向のフレームワークでは、JSX内部でロジックを完結させる必要があるため、ステートメント(文)ではなく式(Expression)を返す三項演算子は事実上の標準となっています。

if..elseから三項演算子への移行:サンプルコード

まずは、基本的な置き換え例を見てみましょう。ユーザーのログイン状態に応じて表示するメッセージを変えるシンプルな例です。


// 従来のif..elseによる記述
let message;
if (isLoggedIn) {
  message = "ようこそ、ユーザーさん";
} else {
  message = "ログインしてください";
}

// 三項演算子による記述
const message = isLoggedIn ? "ようこそ、ユーザーさん" : "ログインしてください";

この例では、変数の再代入(let)を排除し、定数(const)として値を確定させることができています。これにより、変数のライフサイクルが明確になり、バグの混入を防ぐことができます。

次に、Reactコンポーネントでの実践的な例です。条件によってスタイルを切り替えるケースは頻出します。


// Reactコンポーネントでの応用
const Button = ({ isActive }) => (
  <button 
    className={isActive ? "btn-active" : "btn-inactive"}
    disabled={!isActive}
  >
    {isActive ? "送信する" : "待機中..."}
  </button>
);

このように、属性値や子要素の決定において、三項演算子は極めて強力な武器となります。

ネストの罠と回避戦略:可読性の担保

三項演算子の最大の弱点は、ネスト(入れ子)にした時の可読性の低下です。以下のようなコードは、フロントエンド開発において「アンチパターン」とみなされます。


// 避けるべきネスト構造
const status = isError 
  ? "エラーが発生しました" 
  : isLoading 
    ? "読み込み中です" 
    : isSuccess 
      ? "完了しました" 
      : "初期状態";

このようなコードは、人間が一度に理解できる認知負荷を超えています。この問題を解決するためには、以下のいずれかの戦略を採用すべきです。

1. 早期リターン(Early Return)を活用した関数の抽出
2. オブジェクトリテラルによるマッピング(ルックアップテーブル)
3. ユーティリティ関数の作成

特に「オブジェクトリテラル」による条件分岐は、三項演算子よりも遥かにスケーラブルです。


// オブジェクトリテラルによる改善例
const statusMessage = {
  error: "エラーが発生しました",
  loading: "読み込み中です",
  success: "完了しました",
  idle: "初期状態"
};

const getStatus = (state) => statusMessage[state] || statusMessage.idle;

このように、分岐の条件が複雑化する予兆がある場合は、三項演算子に固執せず、データ構造で解決する判断力がプロフェッショナルには求められます。

実務における判断基準:いつ使うべきか

実務の現場でチームメンバーとコードレビューを行う際、以下の基準を設けることを推奨します。

1. 代入目的であるか:変数の初期化や、JSXのプロパティ設定など、値を確定させることが目的であれば三項演算子を優先する。
2. 副作用を伴うか:API通信の実行や、DOMの操作といった「処理(副作用)」を伴う場合は、必ず`if`文を使用する。三項演算子の中で関数を実行するのは、コードの意図が不明瞭になるため避けるべきです。
3. 簡潔さの度合い:三項演算子は「1行で収まる」ことが理想です。改行を多用しなければならないほど複雑な条件分岐は、`if`文やガード句に書き換えるべきです。

また、TypeScriptを使用している場合は、型の絞り込み(Type Narrowing)との相性も重要です。三項演算子は型ガードと組み合わせることで、非常に安全なコードを書くことができます。


// 型ガードとの組み合わせ
const handleAction = (input: string | null) => {
  const result = input ? input.trim() : "デフォルト値";
  console.log(result);
};

このように、`null`チェックと同時に変数を整形するような操作は、三項演算子と非常に相性が良く、コードの安全性を高めます。

まとめ:宣言的なコードを目指して

`if..else`を三項演算子に書き換えることは、単なる構文の好みの問題ではありません。それは、アプリケーションのロジックを「手続き的な命令の羅列」から「データから値を導き出す宣言的な計算」へとシフトさせるプロセスです。

・単純な条件分岐は三項演算子で簡潔に記述する。
・ネストが深くなる場合は、オブジェクトリテラルや関数抽出へ切り替える。
・副作用(関数実行)を伴う処理には、三項演算子を使わず`if`文を使用する。

これらの原則を守ることで、コードベースはより洗練され、メンテナンス性が向上します。フロントエンドのスペシャリストとして、常に「可読性」と「簡潔さ」のバランスを意識し、最適なツールを選択し続けてください。コードは書く時間よりも読まれる時間の方が圧倒的に長いです。未来の自分やチームメンバーが読みやすい、論理的で美しいコードを目指しましょう。

コメント

タイトルとURLをコピーしました