カテゴリ: JavaScript 更新日: 2026/03/30

JavaScriptの条件式におけるnull・undefined判定のコツ!初心者でもわかる判定方法ガイド

JavaScriptの条件式におけるnull・undefined判定のコツ
JavaScriptの条件式におけるnull・undefined判定のコツ

先生と生徒の会話形式で理解しよう

生徒

「先生、JavaScriptで変数がnullやundefinedかどうかを判定したいんですが、どうやってチェックすればいいですか?」

先生

「いい質問ですね。nullundefinedは似ているけど少し違う値で、それぞれを判定するコツがあります。順番に説明しますね。」

生徒

「そもそもnullundefinedって何が違うんですか?」

先生

「まずはそこから説明しますね!」

1. nullとundefinedの違いとは?

1. nullとundefinedの違いとは?
1. nullとundefinedの違いとは?

nullは「値が意図的に存在しない」ことを示します。プログラマーが「ここは空です」と明示的にセットする値です。

undefinedは「値がまだ設定されていない」状態を示します。変数を宣言したけど値を入れていないときに自動的にこの値になります。

簡単に言うと、nullは「空の箱」、undefinedは「まだ箱が用意されていない」状態です。

2. null・undefinedを判定する基本的な方法

2. null・undefinedを判定する基本的な方法
2. null・undefinedを判定する基本的な方法

JavaScriptでnullundefinedかどうかを調べるには、===という「厳密な比較演算子」を使うのがおすすめです。


let value = null;

if (value === null) {
  console.log("値はnullです。");
}

if (value === undefined) {
  console.log("値はundefinedです。");
}

ここでは、valuenullなら一つ目のメッセージが出て、undefinedなら二つ目のメッセージが出ます。

3. nullとundefinedの両方をまとめて判定するコツ

3. nullとundefinedの両方をまとめて判定するコツ
3. nullとundefinedの両方をまとめて判定するコツ

両方とも「値がない状態」なので、一緒に判定したい場合も多いです。そのときは==(ゆるい比較)を使う方法があります。


let value;

if (value == null) {
  console.log("値はnullまたはundefinedです。");
}

== nullnullundefinedのどちらかの場合に真になります。ただし、==は他のケースで予期せぬ動きをすることがあるので注意が必要です。

4. if文の条件でnull・undefinedを判定する場合のポイント

4. if文の条件でnull・undefinedを判定する場合のポイント
4. if文の条件でnull・undefinedを判定する場合のポイント

JavaScriptのif文では、nullundefinedも「false(偽)」として扱われます。つまり、次のように書くと両方をまとめてチェックできます。


let value;

if (!value) {
  console.log("値が設定されていません。");
}

ただし、0や空文字 ""falseも「false」と判定されるため、注意が必要です。もし「値が空かどうか」も区別したいときは別のチェックが必要になります。

5. typeof演算子を使ったundefined判定の方法

5. typeof演算子を使ったundefined判定の方法
5. typeof演算子を使ったundefined判定の方法

typeof演算子は変数の「型」を調べるためのものです。宣言されていない変数を調べるときにも安全に使えます。


if (typeof someVar === "undefined") {
  console.log("someVarはundefinedです。");
}

変数が宣言されていない状態で値を調べるとエラーになりますが、typeofはエラーにならず安全に調べられます。

6. null・undefinedの違いをはっきりさせる実例

6. null・undefinedの違いをはっきりさせる実例
6. null・undefinedの違いをはっきりさせる実例

例えば、ユーザーの入力がまだない場合にnullを使い、変数を宣言したけど値をまだ入れていない場合はundefinedになります。


// ユーザーの入力がまだない
let userInput = null;

// 変数宣言だけした状態
let temp;

console.log(userInput); // null
console.log(temp);      // undefined

7. null・undefined判定のコツまとめ

7. null・undefined判定のコツまとめ
7. null・undefined判定のコツまとめ
  • nullundefinedは似ているが用途や意味が違うので使い分ける。
  • ===を使って厳密に判定するのが安全。
  • nullundefinedのどちらかをまとめて判定したいなら== nullを使う。
  • if(!value)は簡単にまとめてチェックできるが、0や空文字も偽と判定される点に注意。
  • typeof演算子は変数が未定義のときでも安全にundefinedをチェックできる。

8. 実践!null・undefined判定を使ったサンプルコード

8. 実践!null・undefined判定を使ったサンプルコード
8. 実践!null・undefined判定を使ったサンプルコード

最後に実際に判定を使ってみましょう。ユーザーの入力があるかどうかを判定してメッセージを表示する例です。


// ユーザーの名前入力
let userName = null;

if (userName === null) {
  console.log("名前が設定されていません(null)。");
}

if (userName === undefined) {
  console.log("名前が設定されていません(undefined)。");
}

if (userName == null) {
  console.log("名前はnullまたはundefinedです。");
}

if (!userName) {
  console.log("名前は空かnullかundefinedです。");
}

このように状況に合わせて判定方法を使い分けると、意図した条件分岐が書きやすくなります。

まとめ

まとめ
まとめ

JavaScriptにおけるnullとundefinedの判定は、初心者がつまずきやすいポイントのひとつですが、基本的な考え方をしっかり理解しておけば、条件分岐やバグの原因を素早く特定できるようになります。本記事では、nullとundefinedの違いから始まり、厳密比較演算子を使った安全な判定方法、ゆるい比較を活用した効率的なチェック方法、そしてif文における真偽値の扱いまで幅広く解説してきました。 特に重要なのは、nullは意図的に値が存在しない状態を表し、undefinedは値が未定義である状態を示すという違いです。この違いを理解することで、プログラムの設計段階からより明確な意図を持ったコードを書くことができるようになります。 また、JavaScriptの条件式では、falseと判定される値が複数存在するため、単純なif文だけで判定する場合には注意が必要です。nullやundefinedだけを判定したいのか、それとも空文字や数値のゼロも含めて判定したいのかによって、適切な書き方を選ぶ必要があります。 さらに、typeof演算子を使った判定は、未宣言の変数に対しても安全にチェックできるという点で非常に重要です。特に大規模な開発や外部データを扱う場合には、このような安全な書き方がバグの予防につながります。 実務においては、状況に応じて判定方法を使い分けることが求められます。たとえば、APIから取得したデータが存在するかどうかを確認する場合や、ユーザー入力の有無をチェックする場合など、それぞれに適した書き方があります。単に動くコードを書くのではなく、意図が明確で読みやすいコードを書くことが重要です。 JavaScriptの条件分岐や比較演算子を理解することは、フロントエンド開発だけでなく、Node.jsなどのサーバーサイド開発においても非常に役立ちます。今回学んだnull判定、undefined判定、厳密比較、ゆるい比較、typeof演算子の使い方は、今後のプログラミング学習において繰り返し登場する重要な基礎知識です。 以下に、復習として代表的な判定方法をまとめたサンプルコードを掲載します。


// 値の準備
let value;
let data = null;

// 厳密に判定
if (data === null) {
  console.log("dataはnullです");
}

if (value === undefined) {
  console.log("valueはundefinedです");
}

// 両方まとめて判定
if (value == null) {
  console.log("valueはnullまたはundefinedです");
}

// falsyチェック
if (!value) {
  console.log("valueは未設定または空です");
}

// typeofで安全に判定
if (typeof unknownVar === "undefined") {
  console.log("unknownVarは未定義です");
}

dataはnullです
valueはundefinedです
valueはnullまたはundefinedです
valueは未設定または空です
unknownVarは未定義です

このように、複数の判定方法を理解しておくことで、さまざまなケースに柔軟に対応できるようになります。JavaScriptの基礎である条件分岐と値の判定をしっかり身につけて、より実践的なプログラムを書けるようにしていきましょう。

先生と生徒の振り返り会話

生徒

今日の内容で、nullとundefinedの違いがはっきり分かりました。今まではどちらも同じように扱ってしまっていたので、バグの原因になっていた気がします。

先生

それはとても良い気づきですね。JavaScriptではこの二つの違いを理解することがとても大切です。特にデータの状態を正しく扱うためには欠かせない知識です。

生徒

厳密比較のほうが安全だというのも印象に残りました。これからは基本的にイコール三つを使うようにします。

先生

その通りです。まずは厳密比較を基本にして、必要なときだけゆるい比較を使うという考え方が大切です。

生徒

if文でまとめてチェックできるのも便利ですが、ゼロや空文字も含まれる点には注意が必要ですね。

先生

その理解で大丈夫です。条件式は便利ですが、何が含まれているかを意識して使うことが重要です。

生徒

typeofを使えば未定義の変数でもエラーにならないのは安心ですね。実務でも役立ちそうです。

先生

その通りです。特に外部データを扱うときには、安全にチェックできる方法を知っておくことが重要です。今回の内容は何度も使うので、ぜひ繰り返し練習して身につけてください。

関連記事:
カテゴリの一覧へ
新着記事
New1
JavaScript
JavaScriptの条件式におけるnull・undefined判定のコツ!初心者でもわかる判定方法ガイド
New2
JavaScript
JavaScriptの条件式で論理演算子(&&, ||, !)を活用する方法!初心者でもわかる使い方ガイド
New3
TypeScript
TypeScriptでエラー処理を共通関数化して効率的に開発しよう!初心者向け例外処理ガイド
New4
JavaScript
JavaScriptの条件式における比較演算子の使い方まとめ!初心者でもわかる基本ルールと活用法
人気記事
No.1
Java&Spring記事人気No1
JavaScript
JavaScriptのインストール方法まとめ!Windows・Mac・Linux別にステップ解説
No.2
Java&Spring記事人気No2
JavaScript
JavaScriptのtoStringとString関数の違いを初心者向けに解説
No.3
Java&Spring記事人気No3
TypeScript
TypeScriptでコメントを書く正しい書き方と使い分け【初心者向けにやさしく解説】
No.4
Java&Spring記事人気No4
JavaScript
JavaScriptで統一感のあるコードを書くための基本ルール完全ガイド初心者向けコーディング規約入門
No.5
Java&Spring記事人気No5
JavaScript
JavaScriptプログラムの実行方法まとめ!ブラウザ・Node.js・コンソールの使い方
No.6
Java&Spring記事人気No6
JavaScript
JavaScriptでプロジェクトを管理する方法!ディレクトリ構造とファイル管理の基本
No.7
Java&Spring記事人気No7
JavaScript
JavaScriptのonclick・onchangeなどの基本イベントを理解しよう
No.8
Java&Spring記事人気No8
TypeScript
TypeScriptのnever型を使ったエラーハンドリング!例外処理を極める安全なコードの書き方