1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
---
title: 文と宣言
slug: Web/JavaScript/Reference/Statements
tags:
- JavaScript
- Landing page
- Reference
- statements
translation_of: Web/JavaScript/Reference/Statements
---
<div>{{jsSidebar("Statements")}}</div>
<p>JavaScript アプリケーションは、適切な構文で書かれた文から構成されます。ひとつの文が数行に渡る場合もあります。また複数の文それぞれがセミコロンで区切られていれば 1 行となる場合もあります。そのキーワードはひとつではなく、キーワードのグループとなっています。</p>
<h2 id="Statements_and_declarations_by_category" name="Statements_and_declarations_by_category">文と宣言(カテゴリ別)</h2>
<p>アルファベット順リストは左サイドバーで確認できます。</p>
<h3 id="Control_flow" name="Control_flow">フロー制御</h3>
<dl>
<dt>{{jsxref("Statements/block", "ブロック","",1)}}</dt>
<dd>ブロック文は 0 個以上の文をグループ化するのに使います。ブロックは 1 組の波括弧で囲みます。</dd>
<dt>{{jsxref("Statements/break", "break")}}</dt>
<dd>現在実行中のループ、<code>switch</code> による分岐、あるいはラベル文を終了し、その終了した文に続く文へとプログラムの制御を移行します。</dd>
<dt>{{jsxref("Statements/continue", "continue")}}</dt>
<dd>現在実行中のループ、またはラベル付きループで現在反復している文の実行を終了し、そのループの実行を次の反復から継続します。</dd>
<dt>{{jsxref("Statements/Empty", "空文","",1)}}</dt>
<dd>空文は、文が必要ないが JavaScript の文法上 1 つの文が必要な場合に使います。 </dd>
<dt>{{jsxref("Statements/if...else", "if...else")}}</dt>
<dd>与えられた条件が真の場合はある文を実行します。条件が偽の場合はまた別の文を実行できます。</dd>
<dt>{{jsxref("Statements/switch", "switch")}}</dt>
<dd>ある式を評価し、式の値を case 節と照らし合わせ、 case 節に関連付けられた文を実行します。</dd>
<dt>{{jsxref("Statements/throw", "throw")}}</dt>
<dd>ユーザー定義の例外を発生させます。</dd>
<dt>{{jsxref("Statements/try...catch", "try...catch")}}</dt>
<dd>実行を試み、例外が発生した際に行うべき処理を規定する文のブロックを記述します。</dd>
</dl>
<h3 id="Declarations" name="Declarations">宣言</h3>
<dl>
<dt>{{jsxref("Statements/var", "var")}}</dt>
<dd>変数を宣言し、その変数をある値に初期化することもできます。</dd>
<dt>{{jsxref("Statements/let", "let")}}</dt>
<dd>ブロックスコープを持つ局所変数を宣言し、その変数をある値に初期化することもできます。</dd>
<dt>{{jsxref("Statements/const", "const")}}</dt>
<dd>読み取り専用の名前付き定数を宣言します。</dd>
</dl>
<h3 id="Functions_and_classes" name="Functions_and_classes">関数とクラス</h3>
<dl>
<dt>{{jsxref("Statements/function", "function")}}</dt>
<dd>特定の仮引数を持つ関数を宣言します。</dd>
<dt>{{jsxref("Statements/function*", "function*")}}</dt>
<dd><a href="/ja/docs/Web/JavaScript/Reference/Iteration_protocols">イテレーター</a>をより簡単に書けるジェネレーター関数です。</dd>
<dt>{{jsxref("Statements/async_function", "async function")}}</dt>
<dd>指定したパラメーターの非同期関数を定義します。</dd>
<dt>{{jsxref("Statements/return", "return")}}</dt>
<dd>関数によって返される値を指定します。</dd>
<dt>{{jsxref("Statements/class", "class")}}</dt>
<dd>クラスを宣言します。</dd>
</dl>
<h3 id="Iterations" name="Iterations">反復処理</h3>
<dl>
<dt>{{jsxref("Statements/do...while", "do...while")}}</dt>
<dd>テスト条件が偽と評価されるまで指定された文を実行するループを作成します。この条件は文が実行されたあとに評価され、その結果少なくとも 1 回は指定された文が実行されます。</dd>
<dt>{{jsxref("Statements/for", "for")}}</dt>
<dd>丸括弧で囲まれ、セミコロンで区切られた 3 つの式と、それに続くループ内で実行される文から構成されるループを作成します。</dd>
<dt>{{jsxref("Statements/for_each...in", "for each...in")}}</dt>
<dd>オブジェクトプロパティのすべての値を、指定した変数を通して反復処理を行います。それぞれ個別のプロパティに対し、指定した文が実行されます。</dd>
<dt>{{jsxref("Statements/for...in", "for...in")}}</dt>
<dd>オブジェクトの列挙可能なプロパティに対し任意の順番で反復処理を行います。それぞれ個別のプロパティに対し、文を実行できます。</dd>
<dt>{{jsxref("Statements/for...of", "for...of")}}</dt>
<dd>反復可能オブジェクト ({{jsxref("Global_Objects/Array","配列","","true")}}、配列風オブジェクト、<a href="/ja/docs/Web/JavaScript/Guide/Iterators_and_Generators">イテレーターとジェネレーター</a>を含む) を反復処理し、それぞれ個別のプロパティの値に対する実行文をともなった反復処理フックを呼び出します。</dd>
<dt>{{jsxref("Statements/for-await...of", "for await...of")}}</dt>
<dd>非同期反復オブジェクト、配列風オブジェクト、<a href="/ja/docs/JavaScript/Guide/Iterators_and_Generators">イテレーターとジェネレーター</a>を反復処理し、各固有のプロパティ値で実行する文を実行しつつ、カスタムイテレーションフックを実行する。</dd>
<dt>{{jsxref("Statements/while", "while")}}</dt>
<dd>テスト条件が真と評価される間、指定した文を実行するループを作成します。この条件は文が実行される前に評価されます。</dd>
</dl>
<h3 id="Others" name="Others">その他</h3>
<dl>
<dt>{{jsxref("Statements/debugger", "debugger")}}</dt>
<dd>利用可能なデバッグ機能を呼び出します。利用可能なデバッグ機能がない場合、この文は無効となります。</dd>
<dt>{{jsxref("Statements/export", "export")}}</dt>
<dd>外部モジュールや別のスクリプトでインポートできるように、関数をエクスポートするのに使われます。</dd>
<dt>{{jsxref("Statements/import", "import")}}</dt>
<dd>外部モジュールや別のスクリプトからエクスポートされる関数をインポートするのに使われます。</dd>
<dt><a href="/ja/docs/Web/JavaScript/Reference/Statements/import.meta"><code>import.meta</code></a></dt>
<dd>JavaScript モジュールのコンテンツ固有なメタデータを公開するオブジェクト。</dd>
<dt>{{jsxref("Statements/label", "label", "", 1)}}</dt>
<dd><code>break</code> や <code>continue</code> 文を使う際に参照できる識別子を含む文を用意します。</dd>
</dl>
<dl>
<dt>{{jsxref("Statements/with", "with")}} </dt>
<dd>文のスコープチェーンを拡張します。</dd>
</dl>
<h2 id="Specifications" name="Specifications">仕様書</h2>
<table class="standard-table">
<thead>
<tr>
<th scope="col">仕様書</th>
</tr>
</thead>
<tbody>
<tr>
<td>{{SpecName('ESDraft', '#sec-ecmascript-language-statements-and-declarations', 'ECMAScript Language: Statements and Declarations')}}</td>
</tr>
</tbody>
</table>
<h2 id="Browser_compatibility" name="Browser_compatibility">ブラウザーの互換性</h2>
<p>{{Compat("javascript.statements")}}</p>
<h2 id="See_also" name="See_also">関連情報</h2>
<ul>
<li><a href="/ja/docs/Web/JavaScript/Reference/Operators">演算子</a></li>
</ul>
|