aboutsummaryrefslogtreecommitdiff
path: root/files/id/web/javascript/reference/statements/index.html
blob: 08840f4e1ae46a2c8a64d2d60d17969f336e1e7b (plain)
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
129
130
131
132
133
134
135
136
137
138
139
---
title: Statements
slug: Web/JavaScript/Reference/Statements
tags:
  - JavaScript
  - Referensi
  - Statement
translation_of: Web/JavaScript/Reference/Statements
---
<div>{{jsSidebar("Statements")}}</div>

<p>Aplikasi JavaScript terdiri dari statemen dengan sebuah sintaks tertentu. Sebuah statement dapat terdiri lebih dari satu baris. Setiap statement dapat berupa sebaris kode jika di pisahkan dengan semikolon ( ; ). Bukan merupakan keyword, tapi sekumpulan keyword.</p>

<h2 id="Statemen_dan_deklarasi_berdasarkan_kategori">Statemen dan deklarasi berdasarkan kategori</h2>

<p>Untuk daftar berdasarkan alfabet lihat pada sidebar sebelah kiri.</p>

<h3 id="Control_flow">Control flow</h3>

<dl>
 <dt>{{jsxref("Statements/block", "Block")}}</dt>
 <dd>Sebuah block statemen digunakan untuk mengelompokkan zero ( 0 ) atau lebih statement. Block ini dibatasi menggunakan kurung kurawal.</dd>
 <dt>{{jsxref("Statements/break", "break")}}</dt>
 <dd>Membatasi  loop, switch, atau label statement dan transfer kontrol program pada statement berdasakan statemen akhir.</dd>
 <dt>{{jsxref("Statements/continue", "continue")}}</dt>
 <dd>Terminates execution of the statements in the current iteration of the current or labeled loop, and continues execution of the loop with the next iteration.</dd>
 <dt>{{jsxref("Statements/Empty", "Empty")}}</dt>
 <dd>An empty statement is used to provide no statement, although the JavaScript syntax would expect one.</dd>
 <dt>{{jsxref("Statements/if...else", "if...else")}}</dt>
 <dd>Executes a statement if a specified condition is true. If the condition is false, another statement can be executed.</dd>
 <dt>{{jsxref("Statements/switch", "switch")}}</dt>
 <dd>Evaluates an expression, matching the expression's value to a case clause, and executes statements associated with that case.</dd>
 <dt>{{jsxref("Statements/throw", "throw")}}</dt>
 <dd>Throws a user-defined exception.</dd>
 <dt>{{jsxref("Statements/try...catch", "try...catch")}}</dt>
 <dd>Marks a block of statements to try, and specifies a response, should an exception be thrown.</dd>
</dl>

<h3 id="Deklarasi">Deklarasi</h3>

<dl>
 <dt>{{jsxref("Statements/var", "var")}}</dt>
 <dd>Mendeklarasikan variabel, biasanya menginisialisasi ke sebuah nilai.</dd>
 <dt>{{jsxref("Statements/let", "let")}}</dt>
 <dd>Declares a block scope local variable, optionally initializing it to a value.</dd>
 <dt>{{jsxref("Statements/const", "const")}}</dt>
 <dd>Declares a read-only named constant.</dd>
</dl>

<h3 id="Fungsi_dan_class">Fungsi dan class</h3>

<dl>
 <dt>{{jsxref("Statements/function", "function")}}</dt>
 <dd>Declares a function with the specified parameters.</dd>
 <dt>{{jsxref("Statements/function*", "function*")}}</dt>
 <dd>Generators functions enable writing <a href="/en-US/docs/Web/JavaScript/Guide/The_Iterator_protocol">iterators</a> more easily.</dd>
 <dt>{{jsxref("Statements/return", "return")}}</dt>
 <dd>Specifies the value to be returned by a function.</dd>
 <dt>{{jsxref("Statements/class", "class")}}</dt>
 <dd>Declares a class.</dd>
</dl>

<h3 id="Iterations">Iterations</h3>

<dl>
 <dt>{{jsxref("Statements/do...while", "do...while")}}</dt>
 <dd>Creates a loop that executes a specified statement until the test condition evaluates to false. The condition is evaluated after executing the statement, resulting in the specified statement executing at least once.</dd>
 <dt>{{jsxref("Statements/for", "for")}}</dt>
 <dd>Creates a loop that consists of three optional expressions, enclosed in parentheses and separated by semicolons, followed by a statement executed in the loop.</dd>
 <dt>{{deprecated_inline}} {{non-standard_inline()}} {{jsxref("Statements/for_each...in", "for each...in")}}</dt>
 <dd>Iterates a specified variable over all values of object's properties. For each distinct property, a specified statement is executed.</dd>
 <dt>{{jsxref("Statements/for...in", "for...in")}}</dt>
 <dd>Iterates over the enumerable properties of an object, in arbitrary order. For each distinct property, statements can be executed.</dd>
 <dt>{{jsxref("Statements/for...of", "for...of")}}</dt>
 <dd>Iterates over iterable objects (including {{jsxref("Global_Objects/Array","arrays","","true")}}, array-like objects, <a href="/en-US/docs/JavaScript/Guide/Iterators_and_Generators">iterators and generators</a>), invoking a custom iteration hook with statements to be executed for the value of each distinct property.</dd>
 <dt>{{jsxref("Statements/while", "while")}}</dt>
 <dd>Creates a loop that executes a specified statement as long as the test condition evaluates to true. The condition is evaluated before executing the statement.</dd>
</dl>

<h3 id="Others">Others</h3>

<dl>
 <dt>{{jsxref("Statements/debugger", "debugger")}}</dt>
 <dd>Invokes any available debugging functionality. If no debugging functionality is available, this statement has no effect.</dd>
 <dt>{{jsxref("Statements/export", "export")}}</dt>
 <dd>Used to export functions to make them available for imports in external modules, another scripts.</dd>
 <dt>{{jsxref("Statements/import", "import")}}</dt>
 <dd>Used to import functions exported from an external module, another script.</dd>
 <dt>{{jsxref("Statements/label", "label")}}</dt>
 <dd>Provides a statement with an identifier that you can refer to using a <code>break</code> or <code>continue</code> statement.</dd>
</dl>

<dl>
 <dt>{{deprecated_inline}} {{jsxref("Statements/with", "with")}}</dt>
 <dd>Extends the scope chain for a statement.</dd>
</dl>

<h2 id="Specifications">Specifications</h2>

<table class="standard-table">
 <tbody>
  <tr>
   <th scope="col">Specification</th>
   <th scope="col">Status</th>
   <th scope="col">Comment</th>
  </tr>
  <tr>
   <td>{{SpecName('ES1', '#sec-12', 'Statements')}}</td>
   <td>{{Spec2('ES1')}}</td>
   <td>Initial definition</td>
  </tr>
  <tr>
   <td>{{SpecName('ES3', '#sec-12', 'Statements')}}</td>
   <td>{{Spec2('ES3')}}</td>
   <td> </td>
  </tr>
  <tr>
   <td>{{SpecName('ES5.1', '#sec-12', 'Statements')}}</td>
   <td>{{Spec2('ES5.1')}}</td>
   <td> </td>
  </tr>
  <tr>
   <td>{{SpecName('ES6', '#sec-ecmascript-language-statements-and-declarations', 'ECMAScript Language: Statements and Declarations')}}</td>
   <td>{{Spec2('ES6')}}</td>
   <td>New: function*, let, for...of, yield, class</td>
  </tr>
  <tr>
   <td>{{SpecName('ESDraft', '#sec-ecmascript-language-statements-and-declarations', 'ECMAScript Language: Statements and Declarations')}}</td>
   <td>{{Spec2('ESDraft')}}</td>
   <td> </td>
  </tr>
 </tbody>
</table>

<h2 id="See_also">See also</h2>

<ul>
 <li><a href="/en-US/docs/Web/JavaScript/Reference/Operators">Operators</a></li>
</ul>