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
140
141
|
---
title: Sentencias
slug: Web/JavaScript/Referencia/Sentencias
tags:
- JavaScript
- Referencia
- sentencias
translation_of: Web/JavaScript/Reference/Statements
---
<div>{{jsSidebar("Statements")}}</div>
<p>Las aplicaciones JavaScript se componen de sentencias con una sintaxis propia. Una sentencia puede estar formada por múltiples líneas. Puede haber varias sentencias en una sola línea si separamos cada una de las sentencias por un punto y coma. No es una palabra clave, sino un grupo de palabras clave.</p>
<h2 id="Sentencias_y_declaraciones_por_categoría">Sentencias y declaraciones por categoría</h2>
<p>Puedes encontrarlas por orden alfabético en la columna de la izquierda .</p>
<h3 id="Control_de_flujo">Control de flujo</h3>
<dl>
<dt>{{jsxref("Sentencias/block", "Block")}}</dt>
<dd>Un bloque de sentencias se utiliza para agrupar cero o mas sentencias. El bloque se delimita por un par de llaves.</dd>
<dt>{{jsxref("Sentencias/break", "break")}}</dt>
<dd>Finaliza la sentencia actual loop, switch, o label y transfiere el control del programa a la siguiente sentencia de la sentencia finalizada.</dd>
<dt>{{jsxref("Sentencias/continue", "continue")}}</dt>
<dd>Finaliza la ejecucion de las sentencias dentro de la iteracion actual del actual bucle, y continua la ejecucion del bucle con la siguiente iteracion.</dd>
<dt>{{jsxref("Sentencias/Empty", "Empty")}}</dt>
<dd>Una sentencia vacía se utiliza para proveer una "no sentencia", aunque la sintaxis de JavaScript esperaba una.</dd>
<dt>{{jsxref("Sentencias/if...else", "if...else")}}</dt>
<dd>Ejecuta una sentencia si una condición especificada es true. Si la condición es false, otra sentencia puede ser ejecutada.</dd>
<dt>{{jsxref("Sentencias/switch", "switch")}}</dt>
<dd>Evalua una expresión, igualando el valor de la expresión a una clausula case y ejecuta las sentencias asociadas con dicho case.</dd>
<dt>{{jsxref("Sentencias/throw", "throw")}}</dt>
<dd>Lanza una excepción definida por el usuario.</dd>
<dt>{{jsxref("Sentencias/try...catch", "try...catch")}}</dt>
<dd>Marca un bloque de sentencias para ser probadas (try) y especifica una respuesta, en caso de que se lance una excepción.</dd>
</dl>
<h3 id="Declaraciones">Declaraciones</h3>
<dl>
<dt>{{jsxref("Sentencias/var", "var")}}</dt>
<dd>Declara una variable, opcionalmente inicializándola a un valor.</dd>
<dt>{{jsxref("Sentencias/let", "let")}}</dt>
<dd>Declara una variable local de ambito de bloque, opcionalmente inicializándola a un valor.</dd>
<dt>{{jsxref("Sentencias/const", "const")}}</dt>
<dd>Declara una constante de solo lectura.</dd>
</dl>
<h3 id="Funciones">Funciones</h3>
<dl>
<dt>{{jsxref("Sentencias/function", "function")}}</dt>
<dd>Declara una función con los parámetros especificados.</dd>
<dt>{{jsxref("Sentencias/function*", "function*")}}</dt>
<dd>Los generadores de funciones permiten escribir {{jsxref("Iteration_protocols", "iteradores")}} con mas facilidad.</dd>
<dt>{{experimental_inline}} {{jsxref("Statements/async_function", "async function")}}</dt>
<dd>Declara una función asíncrona con los parámetros especificados.</dd>
<dt>{{jsxref("Statements/return", "return")}}</dt>
<dd>Especifica el valor a ser retornado por una función.</dd>
<dt>{{jsxref("Statements/class", "class")}}</dt>
<dd>Declara una clase.</dd>
</dl>
<h3 id="Iteraciones">Iteraciones</h3>
<dl>
<dt>{{jsxref("Sentencias/do...while", "do...while")}}</dt>
<dd>Crea un bucle que ejecuta una instrucción especificada hasta que la condición de prueba se evalúa como falsa. La condición se evalúa después de ejecutar la instrucción, lo que da como resultado que la instrucción especificada se ejecute al menos una vez.</dd>
<dt>{{jsxref("Sentencias/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("Sentencias/for_each...in", "for each...in")}}</dt>
<dd>Itera una variable especificada sobre todos los valores de las propiedades del objeto. Para cada propiedad distinta, se ejecuta una instrucción especificada.</dd>
<dt>{{jsxref("Sentencias/for...in", "for...in")}}</dt>
<dd>Itera sobre las propiedades enumerables de un objeto, en orden albitrario. Para cada propiedad distinta, las instrucciones pueden ser ejecutadas.</dd>
<dt>{{jsxref("Sentencias/for...of", "for...of")}}</dt>
<dd>Iterates over iterable objects (including {{jsxref("Array", "array")}}, array-like objects, <a href="https://developer.mozilla.org/en-US/docs/JavaScript/Guide/Iterators_and_Generators" title="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("Sentencias/while", "while")}}</dt>
<dd>Crea un bucle que ejecuta la instrucción especificada siempre que la condición de prueba se evalúe como verdadera. La condición se evalúa antes de ejecutar la instrucción.</dd>
</dl>
<h3 id="Otros">Otros</h3>
<dl>
<dt>{{jsxref("Sentencias/debugger", "debugger")}}</dt>
<dd>Invoca cualquier funcionalidad de depuración disponible. Si no hay funcionalidad de depuración disponible, esta isntrucción no tiene efecto.</dd>
<dt>{{jsxref("Sentencias/export", "export")}}</dt>
<dd>Usada para permitir a un script firmada proveer propiedades, funciones y objetos a otros scripts firmada o sin firmar. Esta antigua funcionalidad de Netscape ha sido removida y será redefinida por los modulos de ECMAScript 6</dd>
<dt>{{jsxref("Sentencias/import", "import")}}</dt>
<dd>Usada para permitir a un escript importar propiedades, funciones y objetos desde otro script firmado que ha exportado su información. Esta antigua funcionalidad de Netscape ha sido removida y será redefinida por los modulos de ECMAScript 6.</dd>
<dt>{{jsxref("Sentencias/label", "label")}}</dt>
<dd>Provee una instrucción con un identificador que puedes referir usando una instrucción <code>break</code> o <code>continue</code> .</dd>
</dl>
<dl>
<dt>{{deprecated_inline()}} {{jsxref("Sentencias/with", "with")}}</dt>
<dd>Extiende la cadena de alcance para una instrucción.</dd>
</dl>
<h2 id="Especificaciones">Especificaciones</h2>
<table class="standard-table">
<tbody>
<tr>
<th scope="col">Especificación</th>
<th scope="col">Status</th>
<th scope="col">Comentario</th>
</tr>
<tr>
<td>{{SpecName('ES1', '#sec-12', 'Statements')}}</td>
<td>{{Spec2('ES1')}}</td>
<td>Definición inicial</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>Nuevo: 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="Vea_También">Vea También</h2>
<ul>
<li><a href="/es/docs/Web/JavaScript/Referencia/Operadores">Operadores</a></li>
</ul>
|