From 7fe91b7974cad70612224a6d368f87948a40e9e2 Mon Sep 17 00:00:00 2001 From: Masahiro FUJIMOTO Date: Sun, 9 Jan 2022 13:04:44 +0900 Subject: Web/JavaScript/Reference/Global_Objects 以下のプロパティを変換準備 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../reference/global_objects/undefined/index.md | 141 +++++++++++++++++++++ 1 file changed, 141 insertions(+) create mode 100644 files/ja/web/javascript/reference/global_objects/undefined/index.md (limited to 'files/ja/web/javascript/reference/global_objects/undefined/index.md') diff --git a/files/ja/web/javascript/reference/global_objects/undefined/index.md b/files/ja/web/javascript/reference/global_objects/undefined/index.md new file mode 100644 index 0000000000..d4f0e54903 --- /dev/null +++ b/files/ja/web/javascript/reference/global_objects/undefined/index.md @@ -0,0 +1,141 @@ +--- +title: undefined +slug: Web/JavaScript/Reference/Global_Objects/undefined +tags: + - JavaScript + - Language feature + - Reference + - 言語機能 +translation_of: Web/JavaScript/Reference/Global_Objects/undefined +--- +
{{jsSidebar("Objects")}}
+ +

グローバルの undefined プロパティはプリミティブ値 {{Glossary("Undefined", "undefined")}} を表します。これは JavaScript における{{Glossary("Primitive", "プリミティブ型")}}の一つです。

+ +

{{js_property_attributes(0,0,0)}}

+ +
{{EmbedInteractiveExample("pages/js/globalprops-undefined.html")}}
+ + + +

構文

+ +
undefined
+ +

解説

+ +

undefined は、グローバルオブジェクトのプロパティです。すなわちグローバルスコープ内の変数です。 undefined の初期値はプリミティブ値である {{Glossary("Undefined", "undefined")}} です。

+ +

最近のブラウザー (JavaScript 1.8.5 / Firefox 4 以降) での undefined は、 ECMAScript 5 仕様により、設定不可、書込不可のプロパティとなります。 (そうでない場合でも、上書きは避けてください。)

+ +

まだ値が代入されていない変数は undefined 型となります。評価しようとしている変数に値が代入されていない場合、メソッドや文も undefined を返します。値を {{jsxref("Statements/return", "return")}} しない関数も undefined を返します。

+ +
+

ご注意ください グローバルスコープ以外のスコープでは{{Glossary("Identifier", "識別子")}} (変数名) として使うことができますが (undefined は{{jsxref("Reserved_Words", "予約語", "", 1)}}でないため)、コードの管理やデバッグが困難になるためおすすめできません。

+ +
//こんなことはしないこと!
+
+// "foo string" をログ出力する
+(function() {
+  var undefined = 'foo';
+  console.log(undefined, typeof undefined);
+})();
+
+// "foo string" をログ出力する
+(function(undefined) {
+  console.log(undefined, typeof undefined);
+})('foo');
+
+
+ +

+ +

厳密等価と undefined

+ +

undefined と厳密等価・非等価演算子を使って、変数に値があるか調べることができます。次のコードでは、変数 x が定義されていないため、 if 文は true に評価されます。

+ +
var x;
+if (x === undefined) {
+  // ここの文は実行される
+}
+else {
+  // ここの文は実行されない
+}
+
+ +
+

注: ここでは、標準の等価演算子ではなく厳密等価演算子を使わないといけません。厳密等価演算子とは違い、 x == undefined は、 xnull であるかどうかもチェックするからです。 nullundefined と等しくありません。

+ +

詳しくは、{{jsxref("Operators/Comparison_Operators", "比較演算子","","true")}}を参照してください。

+
+ +

typeof 演算子と undefined

+ +

代わりに、 {{jsxref("Operators/typeof", "typeof")}} を使用することができます。

+ +
var x;
+if (typeof x === 'undefined') {
+   // ここの文は実行される
+}
+
+ +

{{jsxref("Operators/typeof", "typeof")}} を使う理由の一つとして、こちらは変数が宣言されていなくてもエラーにはなりません。

+ +
// 直前まで x は宣言されていない
+if (typeof x === 'undefined') { // エラーなしで true と評価される
+   // ここの文は実行される
+}
+
+if (x === undefined) { // ReferenceError が発生
+
+}
+
+ +

しかし、もう一つの選択肢があります。JavaScriptは静的にスコープされた言語なので、変数が宣言されているかどうかを知るには、それが含まれるコンテキストで宣言されているかどうかを見ることで読み取ることができます。

+ +

グローバルスコープは{{jsxref("globalThis", "グローバルオブジェクト", "", 1)}}に結びつけられているので、グローバルコンテキストに変数が存在するかどうかのチェックは、グローバルオブジェクトにプロパティが存在することを、 {{jsxref("Operators/in", "in")}} 演算子を使用してチェックすることで行うことができます。

+ +
if ('x' in window) {
+  // x がグローバルに定義されている場合のみ、ここの文を実行
+}
+ +

void 演算子と undefined

+ +

3 つ目の方法として、{{jsxref("Operators/void", "void")}} 演算子があります。

+ +
var x;
+if (x === void 0) {
+  // ここの文は実行される
+}
+
+// 直前まで y は宣言されていない
+if (y === void 0) {
+  // ReferenceError: y is not defined が発生
+}
+
+ +

仕様書

+ + + + + + + + + + + + +
仕様書
{{SpecName('ESDraft', '#sec-undefined', 'undefined')}}
+ +

ブラウザーの互換性

+ +

{{Compat("javascript.builtins.undefined")}}

+ +

関連情報

+ + -- cgit v1.2.3-54-g00ecf