From 4c5d49fa3fc320b0f9557012c3102aef1befc0c5 Mon Sep 17 00:00:00 2001 From: Masahiro FUJIMOTO Date: Thu, 23 Sep 2021 12:10:13 +0900 Subject: Web/JavaScript/Reference/Operators を更新 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Markdown に変換 - 2021/08/31 時点の英語版に同期 --- .../ja/web/javascript/reference/operators/index.md | 483 +++++++++------------ 1 file changed, 217 insertions(+), 266 deletions(-) diff --git a/files/ja/web/javascript/reference/operators/index.md b/files/ja/web/javascript/reference/operators/index.md index aa1fde203b..c5b135ee13 100644 --- a/files/ja/web/javascript/reference/operators/index.md +++ b/files/ja/web/javascript/reference/operators/index.md @@ -4,294 +4,245 @@ slug: Web/JavaScript/Reference/Operators tags: - JavaScript - Landing page - - Operators - - Overview - - Reference - - 概要 - 演算子 + - 概要 + - Reference +browser-compat: javascript.operators translation_of: Web/JavaScript/Reference/Operators --- -
{{JSSidebar("Operators")}}
- -

この節では、JavaScript 言語のすべての演算子、式、キーワードについて記述しています。

- -

式と演算子 (カテゴリー別)

- -

アルファベット順の一覧は左側のサイドバーをご覧ください。

- -

基本式

- -

JavaScript の基本的なキーワードと一般的な式です。

- -
-
{{JSxRef("Operators/this", "this")}}
-
this キーワードは関数の実行コンテキストを参照します。
-
{{JSxRef("Operators/function", "function")}}
-
function キーワードは関数式を定義します。
-
{{JSxRef("Operators/class", "class")}}
-
class キーワードはクラス式を定義します。
-
{{JSxRef("Operators/function*", "function*")}}
-
function* キーワードはジェネレーター関数式を定義します。
-
{{JSxRef("Operators/yield", "yield")}}
-
ジェネレーター関数の一時停止と再開を行います。
-
{{JSxRef("Operators/yield*", "yield*")}}
-
別のジェネレーター関数または反復可能オブジェクトを代行します。
-
{{JSxRef("Operators/async_function", "async function")}}
-
async function は非同期の関数式を定義します。
-
{{JSxRef("Operators/await", "await")}}
-
非同期関数式の停止/再開と、プロミスの解決/拒否を待ちます。
-
{{JSxRef("Global_Objects/Array", "[]")}}
-
配列初期化子またはリテラル構文です。
-
{{JSxRef("Operators/Object_initializer", "{}")}}
-
オブジェクト初期化子またはリテラル構文です。
-
{{JSxRef("Global_Objects/RegExp", "/ab+c/i")}}
-
正規表現式のリテラル構文です。
-
{{JSxRef("Operators/Grouping", "( )")}}
-
グループ化演算子です。
-
- -

左辺式

- -

左辺値は、代入の対象になります。

- -
-
{{JSxRef("Operators/Property_accessors", "プロパティアクセサー", "", 1)}}
-
プロパティアクセス演算子はオブジェクトのプロパティやメソッドへのアクセスを提供します
- (object.propertyobject["property"])。
-
{{JSxRef("Operators/new", "new")}}
-
new 演算子はコンストラクターのインスタンスを作成します。
-
{{JSxRef("Operators/new%2Etarget", "new.target")}}
-
コンストラクター内で new.target を使うことで、{{jsxref("Operators/new", "new")}} によって呼び出されるコンストラクターを参照できます。
-
{{JSxRef("Statements/import%2Emeta", "import.meta")}}
-
コンテキストに依存したメタデータを JavaScript モジュールへ公開するオブジェクトです。
-
{{JSxRef("Operators/super", "super")}}
-
super キーワードは親コンストラクターを呼び出します。
-
{{JSxRef("Operators/Spread_syntax", "...obj")}}
-
展開記法 (スプレッド記法) は、式を複数の引数または複数の要素に展開して、それぞれ関数呼び出しまたは配列リテラルに渡します。
-
- -

インクリメントとデクリメント

- -

接尾/接頭辞のインクリメント演算子と接尾/接頭辞のデクリメント演算子です。

- -
-
{{JSxRef("Operators/Increment", "A++")}}
-
後置型インクリメント演算子。
-
{{JSxRef("Operators/Decrement", "A--")}}
-
後置型デクリメント演算子。
-
{{JSxRef("Operators/Increment", "++A")}}
-
前置型インクリメント演算子。
-
{{JSxRef("Operators/Decrement", "--A")}}
-
前置型デクリメント演算子。
-
- -

単項演算子

- -

単項演算は、1 個のオペランドによる演算です。

- -
-
{{JSxRef("Operators/delete", "delete")}}
-
delete 演算子は、オブジェクトからプロパティを削除します。
-
{{JSxRef("Operators/void", "void")}}
-
void 演算子は、式の戻り値を破棄します。
-
{{JSxRef("Operators/typeof", "typeof")}}
-
typeof 演算子は、与えられたオブジェクトの型を判別します。
-
{{JSxRef("Operators/Unary_plus", "+")}}
-
単項正値演算子は、そのオペランドを Number 型に変換します。
-
{{JSxRef("Operators/Unary_negation", "-")}}
-
単項負値演算子は、そのオペランドを Number 型に変換して正負を反転します。
-
{{JSxRef("Operators/Bitwise_NOT", "~")}}
-
ビット否定演算子です。
-
{{JSxRef("Operators/Logical_NOT", "!")}}
-
論理否定演算子です。
-
+{{JSSidebar("Operators")}} + +この節では、JavaScript 言語のすべての演算子、式、キーワードについて記述しています。 + +## 式と演算子 (カテゴリー別) + +アルファベット順の一覧は左側のサイドバーをご覧ください。 + +### 基本式 + +JavaScript の基本的なキーワードと一般的な式です。 + +- {{JSxRef("Operators/this", "this")}} + - : `this` キーワードは関数の実行コンテキストを参照します。 +- {{JSxRef("Operators/function", "function")}} + - : `function` キーワードは関数式を定義します。 +- {{JSxRef("Operators/class", "class")}} + - : `class` キーワードはクラス式を定義します。 +- {{JSxRef("Operators/function*", "function*")}} + - : `function*` キーワードはジェネレーター関数式を定義します。 +- {{JSxRef("Operators/yield", "yield")}} + - : ジェネレーター関数の一時停止と再開を行います。 +- {{JSxRef("Operators/yield*", "yield*")}} + - : 別のジェネレーター関数または反復可能オブジェクトを代行します。 +- {{JSxRef("Operators/async_function", "async function")}} + - : `async function` は非同期の関数式を定義します。 +- {{JSxRef("Operators/await", "await")}} + - : 非同期関数式の停止/再開と、プロミスの解決/拒否を待ちます。 +- {{JSxRef("Global_Objects/Array", "[]")}} + - : 配列初期化子またはリテラル構文です。 +- {{JSxRef("Operators/Object_initializer", "{}")}} + - : オブジェクト初期化子またはリテラル構文です。 +- {{JSxRef("Global_Objects/RegExp", "/ab+c/i")}} + - : 正規表現式のリテラル構文です。 +- {{JSxRef("Operators/Grouping", "( )")}} + - : グループ化演算子です。 + +### 左辺式 + +左辺値は、代入の対象になります。 + +- {{JSxRef("Operators/Property_accessors", "プロパティアクセサー", "", 1)}} + - : プロパティアクセス演算子はオブジェクトのプロパティやメソッドへのアクセス (`object.property` や `object["property"]`) を提供します。 +- {{JSxRef("Operators/new", "new")}} + - : `new` 演算子はコンストラクターのインスタンスを作成します。 +- {{JSxRef("Operators/new%2Etarget", "new.target")}} + - : コンストラクター内で `new.target` を使うことで、{{JSxRef("Operators/new", "new")}} によって呼び出されるコンストラクターを参照できます。 +- {{JSxRef("Statements/import%2Emeta", "import.meta")}} + - : コンテキストに依存したメタデータを JavaScript モジュールへ公開するオブジェクトです。 +- {{JSxRef("Operators/super", "super")}} + - : `super` キーワードは親コンストラクターを呼び出します。 +- {{JSxRef("Operators/Spread_syntax", "...obj")}} + - : 展開記法 (スプレッド記法) は、式を複数の引数または複数の要素に展開して、それぞれ関数呼び出しまたは配列リテラルに渡します。 + +### インクリメントとデクリメント + +接尾/接頭辞のインクリメント演算子と接尾/接頭辞のデクリメント演算子です。 + +- {{JSxRef("Operators/Increment", "A++")}} + - : 後置型インクリメント演算子。 +- {{JSxRef("Operators/Decrement", "A--")}} + - : 後置型デクリメント演算子。 +- {{JSxRef("Operators/Increment", "++A")}} + - : 前置型インクリメント演算子。 +- {{JSxRef("Operators/Decrement", "--A")}} + - : 前置型デクリメント演算子。 + +### 単項演算子 + +単項演算は、1 個のオペランドによる演算です。 + +- {{JSxRef("Operators/delete", "delete")}} + - : `delete` 演算子は、オブジェクトからプロパティを削除します。 +- {{JSxRef("Operators/void", "void")}} + - : `void` 演算子は、式の戻り値を破棄します。 +- {{JSxRef("Operators/typeof", "typeof")}} + - : `typeof` 演算子は、与えられたオブジェクトの型を判別します。 +- {{JSxRef("Operators/Unary_plus", "+")}} + - : 単項正値演算子は、そのオペランドを Number 型に変換します。 +- {{JSxRef("Operators/Unary_negation", "-")}} + - : 単項負値演算子は、そのオペランドを Number 型に変換して正負を反転します。 +- {{JSxRef("Operators/Bitwise_NOT", "~")}} + - : ビット否定演算子です。 +- {{JSxRef("Operators/Logical_NOT", "!")}} + - : 論理否定演算子です。

算術演算子

-

算術演算子は、数値 (リテラルまたは値) をオペランドとして取り、1 個の数値を返します。

- -
-
{{JSxRef("Operators/Addition", "+")}}
-
加算演算子です。
-
{{JSxRef("Operators/Subtraction", "-")}}
-
減算演算子です。
-
{{JSxRef("Operators/Division", "/")}}
-
除算演算子です。
-
{{JSxRef("Operators/Multiplication", "*")}}
-
乗算演算子です。
-
{{JSxRef("Operators/Remainder", "%")}}
-
剰余演算子です。
-
{{JSxRef("Operators/Exponentiation", "**")}}
-
べき乗演算子です。
-
- -

関係演算子

- -

比較演算子は、そのオペランドを比較し、その比較が真かどうかに基づいて Boolean 値を返します。

- -
-
{{JSxRef("Operators/in", "in")}}
-
in 演算子は、与えられたプロパティをオブジェクトが持っているかどうかを判別します。
-
{{JSxRef("Operators/instanceof", "instanceof")}}
-
instanceof 演算子は、オブジェクトが別のオブジェクトのインスタンスかどうかを判別します。
-
{{JSxRef("Operators/Less_than", "<")}}
-
小なり演算子です。
-
{{JSxRef("Operators/Greater_than", ">")}}
-
大なり演算子です。
-
{{JSxRef("Operators/Less_than_or_equal", "<=")}}
-
小なりイコール演算子です。
-
{{JSxRef("Operators/Greater_than_or_equal", ">=")}}
-
大なりイコール演算子です。
-
- -
-

注: => は演算子ではなく、アロー関数 のための記法です。

-
+算術演算子は、数値 (リテラルまたは値) をオペランドとして取り、1 個の数値を返します。 + +- {{JSxRef("Operators/Addition", "+")}} + - : 加算演算子です。 +- {{JSxRef("Operators/Subtraction", "-")}} + - : 減算演算子です。 +- {{JSxRef("Operators/Division", "/")}} + - : 除算演算子です。 +- {{JSxRef("Operators/Multiplication", "*")}} + - : 乗算演算子です。 +- {{JSxRef("Operators/Remainder", "%")}} + - : 剰余演算子です。 +- {{JSxRef("Operators/Exponentiation", "**")}} + - : べき乗演算子です。 + +### 関係演算子 + +比較演算子は、そのオペランドを比較し、その比較が真かどうかに基づいて `Boolean` 値を返します。 + +- {{JSxRef("Operators/in", "in")}} + - : `in` 演算子は、与えられたプロパティをオブジェクトが持っているかどうかを判別します。 +- {{JSxRef("Operators/instanceof", "instanceof")}} + - : `instanceof` 演算子は、オブジェクトが別のオブジェクトのインスタンスかどうかを判別します。 +- {{JSxRef("Operators/Less_than", "<")}} + - : 小なり演算子です。 +- {{JSxRef("Operators/Greater_than", ">")}} + - : 大なり演算子です。 +- {{JSxRef("Operators/Less_than_or_equal", "<=")}} + - : 小なりイコール演算子です。 +- {{JSxRef("Operators/Greater_than_or_equal", ">=")}} + - : 大なりイコール演算子です。 + +> **Note:** `=>` は演算子ではなく、[アロー関数](/ja/docs/Web/JavaScript/Reference/Functions/Arrow_functions)のための記法です。

等値演算子

-

等値演算子の評価結果は常に、比較が真かどうかに基づいて Boolean 型の値になります。

+等値演算子の評価結果は常に、比較が真かどうかに基づいて `Boolean` 型の値になります。 -
-
{{JSxRef("Operators/Equality", "==")}}
-
等値演算子です。
-
{{JSxRef("Operators/Inequality", "!=")}}
-
不等値演算子です。
-
{{JSxRef("Operators/Strict_equality", "===")}}
-
同値演算子です。
-
{{JSxRef("Operators/Strict_inequality", "!==")}}
-
非同値演算子です。
-
+- {{JSxRef("Operators/Equality", "==")}} + - : 等値演算子です。 +- {{JSxRef("Operators/Inequality", "!=")}} + - : 不等値演算子です。 +- {{JSxRef("Operators/Strict_equality", "===")}} + - : 同値演算子です。 +- {{JSxRef("Operators/Strict_inequality", "!==")}} + - : 非同値演算子です。

ビットシフト演算子

-

オペランドのすべてのビットをシフト演算します。

- -
-
{{JSxRef("Operators/Left_shift", "<<")}}
-
ビット左シフト演算子です。
-
{{JSxRef("Operators/Right_shift", ">>")}}
-
ビット右シフト演算子です。
-
{{JSxRef("Operators/Unsigned_right_shift", ">>>")}}
-
ビット符号なし右シフト演算子です。
-
- -

バイナリービット演算子

- -

ビット演算子は、そのオペランドを 32 ビット (0 と 1) の並びとして扱い、標準の JavaScript 数値を返します。

- -
-
{{JSxRef("Operators/Bitwise_AND", "&")}}
-
ビット論理積 (AND) です。
-
{{JSxRef("Operators/Bitwise_OR", "|")}}
-
ビット論理和 (OR) です。
-
{{JSxRef("Operators/Bitwise_XOR", "^")}}
-
ビット排他的論理和 (XOR) です。
-
- -

バイナリー論理演算子

- -

論理演算には、一般的に (論理) 真偽値が使用され、それが置かれた時に真偽値を返します。

- -
-
{{JSxRef("Operators/Logical_AND", "&&")}}
-
論理積 (AND) です。
-
{{JSxRef("Operators/Logical_OR", "||")}}
-
論理和 (OR) です。
-
{{JSxRef("Operators/Nullish_coalescing_operator", "??")}}
-
Null 合体演算子です。
-
- -

条件 (三項) 演算子

- -
-
{{JSxRef("Operators/Conditional_Operator", "(condition ? ifTrue : ifFalse)")}}
-
-

この条件演算子は、条件の論理値を基に、2 つの値のいずれか一方を返します。

-
-
- -

オプショナルチェイニング演算子

- -
-
{{JSxRef("Operators/Optional_chaining", "?.")}}
-
-

オプショナルチェイニング演算子は、参照が nullishnull または undefined)の場合にエラーを発生させるのではなく、undefined を返します。

-
-
+オペランドのすべてのビットをシフト演算します。 + +- {{JSxRef("Operators/Left_shift", "<<")}} + - : ビット左シフト演算子です。 +- {{JSxRef("Operators/Right_shift", ">>")}} + - : ビット右シフト演算子です。 +- {{JSxRef("Operators/Unsigned_right_shift", ">>>")}} + - : ビット符号なし右シフト演算子です。 + +### バイナリービット演算子 + +ビット演算子は、そのオペランドを 32 ビット (0 と 1) の並びとして扱い、標準の JavaScript 数値を返します。 + +- {{JSxRef("Operators/Bitwise_AND", "&")}} + - : ビット論理積 (AND) です。 +- {{JSxRef("Operators/Bitwise_OR", "|")}} + - : ビット論理和 (OR) です。 +- {{JSxRef("Operators/Bitwise_XOR", "^")}} + - : ビット排他的論理和 (XOR) です。 + +### バイナリー論理演算子 + +論理演算には、一般的に (論理) 真偽値が使用され、それが置かれた時に真偽値を返します。 + +- {{JSxRef("Operators/Logical_AND", "&&")}} + - : 論理積 (AND) です。 +- {{JSxRef("Operators/Logical_OR", "||")}} + - : 論理和 (OR) です。 +- {{JSxRef("Operators/Nullish_coalescing_operator", "??")}} + - : Null 合体演算子です。 + +### 条件 (三項) 演算子 + +- {{JSxRef("Operators/Conditional_Operator", "(条件 ? 真の場合 : 負の場合)")}} + - : この条件演算子は、条件の論理値を基に、2 つの値のいずれか一方を返します。 + +

オプショナルチェーン演算子

+ +- {{JSxRef("Operators/Optional_chaining", "?.")}} + - : オプショナルチェーン演算子は、参照が [nullish](/ja/docs/Glossary/Nullish) ([`null`](/ja/docs/Web/JavaScript/Reference/Global_Objects/null) または [`undefined`](/ja/docs/Web/JavaScript/Reference/Global_Objects/undefined)) の場合にエラーを発生させるのではなく、`undefined` を返します。 +

代入演算子

-

代入演算子は、右辺のオペランドに基づいて、値を左辺のオペランドに代入します。

- -
-
{{JSxRef("Operators/Assignment", "=")}}
-
代入演算子です。
-
{{JSxRef("Operators/Multiplication_assignment", "*=")}}
-
乗算値を代入します。
-
{{JSxRef("Operators/Exponentiation_assignment", "**=")}}
-
べき乗値を代入します。
-
{{JSxRef("Operators/Division_assignment", "/=")}}
-
除算値を代入します。
-
{{JSxRef("Operators/Remainder_assignment", "%=")}}
-
剰余値を代入します。
-
{{JSxRef("Operators/Addition_assignment", "+=")}}
-
加算値を代入します。
-
{{JSxRef("Operators/Subtraction_assignment", "-=")}}
-
減算値を代入します。
-
{{JSxRef("Operators/Left_shift_assignment", "<<=")}}
-
左シフトした値を代入します。
-
{{JSxRef("Operators/Right_shift_assignment", ">>=")}}
-
右シフトした値を代入します。
-
{{JSxRef("Operators/Unsigned_right_shift_assignment", ">>>=")}}
-
符号なしの右シフトした値を代入します。
-
{{JSxRef("Operators/Bitwise_AND_assignment", "&=")}}
-
ビット論理積 (AND) の値を代入します。
-
{{JSxRef("Operators/Bitwise_XOR_assignment", "^=")}}
-
ビット排他的論理和 (XOR) の値を代入します。
-
{{JSxRef("Operators/Bitwise_OR_assignment", "|=")}}
-
ビット論理和 (OR) の値を代入します。
-
{{JSxRef("Operators/Logical_AND_assignment", "&&=")}}
-
論理積代入です。
-
{{JSxRef("Operators/Logical_OR_assignment", "||=")}}
-
論理和代入です。
-
{{JSxRef("Operators/Logical_nullish_assignment", "??=")}}
-
論理 Null 代入です。
-
{{JSxRef("Operators/Destructuring_assignment", "[a, b] = [1, 2]")}}
- {{JSxRef("Operators/Destructuring_assignment", "{a, b} = {a:1, b:2}")}}
-
-

分割代入は、配列やオブジェクトのプロパティを、配列やオブジェクトリテラルに似た構文を使用して変数に代入します。

-
-
+代入演算子は、右辺のオペランドに基づいて、値を左辺のオペランドに代入します。 + +- {{JSxRef("Operators/Assignment", "=")}} + - : 代入演算子です。 +- {{JSxRef("Operators/Multiplication_assignment", "*=")}} + - : 乗算値を代入します。 +- {{JSxRef("Operators/Exponentiation_assignment", "**=")}} + - : べき乗値を代入します。 +- {{JSxRef("Operators/Division_assignment", "/=")}} + - : 除算値を代入します。 +- {{JSxRef("Operators/Remainder_assignment", "%=")}} + - : 剰余値を代入します。 +- {{JSxRef("Operators/Addition_assignment", "+=")}} + - : 加算値を代入します。 +- {{JSxRef("Operators/Subtraction_assignment", "-=")}} + - : 減算値を代入します。 +- {{JSxRef("Operators/Left_shift_assignment", "<<=")}} + - : 左シフトした値を代入します。 +- {{JSxRef("Operators/Right_shift_assignment", ">>=")}} + - : 右シフトした値を代入します。 +- {{JSxRef("Operators/Unsigned_right_shift_assignment", ">>>=")}} + - : 符号なしの右シフトした値を代入します。 +- {{JSxRef("Operators/Bitwise_AND_assignment", "&=")}} + - : ビット論理積 (AND) の値を代入します。 +- {{JSxRef("Operators/Bitwise_XOR_assignment", "^=")}} + - : ビット排他的論理和 (XOR) の値を代入します。 +- {{JSxRef("Operators/Bitwise_OR_assignment", "|=")}} + - : ビット論理和 (OR) の値を代入します。 +- {{JSxRef("Operators/Logical_AND_assignment", "&&=")}} + - : 論理積代入です。 +- {{JSxRef("Operators/Logical_OR_assignment", "||=")}} + - : 論理和代入です。 +- {{JSxRef("Operators/Logical_nullish_assignment", "??=")}} + - : 論理 Null 代入です。 +- {{JSxRef("Operators/Destructuring_assignment", "[a, b] = [1, 2]")}} + {{JSxRef("Operators/Destructuring_assignment", "{a, b} = {a:1, b:2}")}} + - : 分割代入は、配列やオブジェクトのプロパティを、配列やオブジェクトリテラルに似た構文を使用して変数に代入します。 +

カンマ演算子

-
-
{{JSxRef("Operators/Comma_Operator", ",")}}
-
カンマ演算子は、複数の式を単一の文で評価し、その最後の式の結果を返します。
-
+- {{JSxRef("Operators/Comma_Operator", ",")}} + - : カンマ演算子は、複数の式を単一の文で評価し、その最後の式の結果を返します。 -

仕様書

+## 仕様書 - - - - - - - - - - - -
仕様書
{{SpecName('ESDraft', '#sec-ecmascript-language-expressions', 'ECMAScript Language: Expressions')}}
+{{Specifications}} -

ブラウザーの互換性

+## ブラウザーの互換性 -

{{Compat("javascript.operators")}}

+{{Compat}} -

関連情報

+## 関連情報 - +- [演算子の優先順位](/ja/docs/Web/JavaScript/Reference/Operators/Operator_Precedence) -- cgit v1.2.3-54-g00ecf