Este capítulo resume brevemente las características de JavaScript que hemos aprendido hasta ahora, prestando especial atención a los detalles relevantes.
Estructura de Código
Las declaraciones se delimitan con un punto y coma:
alert('Hola'); alert('Mundo');
En general, un salto de línea también se trata como un delimitador, por lo que también funciona:
alert('Hola')
alert('Mundo')
Esto se llama “inserción automática de punto y coma”. A veces no funciona, por ejemplo:
alert("Habrá un error después de este mensaje.")
[1, 2].forEach(alert)
La mayoría de las guías de estilo de código coinciden en que debemos poner un punto y coma después de cada declaración.
Los puntos y comas no son necesarios después de los bloques de código {...}
y los constructores de sintaxis como los bucles:
function f() {
// no se necesita punto y coma después de la declaración de función
}
for(;;) {
// no se necesita punto y coma después del bucle
}
…Pero incluso si colocásemos un punto y coma “extra” en alguna parte, eso no sería un error. Solo sería ignorado.
Más en: Estructura del código.
Modo estricto
Para habilitar completamente todas las características de JavaScript moderno, debemos comenzar los scripts con "use strict"
.
'use strict';
...
La directiva debe estar en la parte superior de un script o al comienzo de una función.
Sin la directiva "use strict"
todo sigue funcionando, pero algunas características se comportan de la manera antigua y “compatible”. Generalmente preferimos el comportamiento moderno.
Algunas características modernas del lenguaje (como las clases que estudiaremos en el futuro) activan el modo estricto implícitamente.
Más en: El modo moderno, "use strict".
Variables
Se pueden declarar usando:
let
const
(constante, no se puede cambiar)var
(estilo antiguo, lo veremos más tarde)
Un nombre de variable puede incluir:
- Letras y dígitos, pero el primer carácter no puede ser un dígito.
- Los caracteres
$
y_
son normales, al igual que las letras. - Los alfabetos y jeroglíficos no latinos también están permitidos, pero comúnmente no se usan.
Las variables se escriben dinámicamente. Pueden almacenar cualquier valor:
let x = 5;
x = "John";
Hay 8 tipos de datos:
number
tanto para números de punto flotante como enteros,bigint
para números enteros de largo arbitrario,string
para textos,boolean
para valores lógicos:true/false
,null
– un tipo con el valor úniconull
, que significa “vacío” o “no existe”,undefined
– un tipo con el valor únicoundefined
, que significa “no asignado”,object
ysymbol
– para estructuras de datos complejas e identificadores únicos, aún no los hemos aprendido.
El operador typeof
devuelve el tipo de un valor, con dos excepciones:
typeof null == "object" // error del lenguaje
typeof function(){} == "function" // las funciones son tratadas especialmente
Más en: Variables y Tipos de datos.
Interacción
Estamos utilizando un navegador como entorno de trabajo, por lo que las funciones básicas de la interfaz de usuario serán:
prompt(question, [default])
- Hace una pregunta
question
, y devuelve lo que ingresó el visitante onull
si presiona “cancelar”. confirm(question)
- Hace una pregunta
question
, y sugiere elegir entre Aceptar y Cancelar. La elección se devuelve como booleanotrue/false
. alert(message)
- Muestra un
message
.
Todas estas funciones son modales, pausan la ejecución del código y evitan que el visitante interactúe con la página hasta que responda.
Por ejemplo:
let userName = prompt("¿Su nombre?", "Alice");
let isTeaWanted = confirm("¿Quiere té?");
alert( "Visitante: " + userName ); // Alice
alert( "Quiere té: " + isTeaWanted ); // true
Más en: Interacción: alert, prompt, confirm.
Operadores
JavaScript soporta los siguientes operadores:
- Aritméticos
-
Los normales:
* + - /
, también%
para los restos y**
para aplicar potencia de un número.El binario más
+
concatena textos. Si uno de los operandos es un texto, el otro también se convierte en texto:alert( '1' + 2 ); // '12', texto alert( 1 + '2' ); // '12', texto
- Asignaciones
-
Existen las asignaciones simples:
a = b
y las combinadasa *= 2
. - Operador bit a bit
-
Los operadores bit a bit funcionan con enteros de 32 bits al más bajo nivel, el de bit: vea la documentación cuando los necesite.
- Condicional
-
El único operador con 3 parámetros:
cond ? resultA : resultB
. Sícond
es verdadera, devuelveresultA
, de lo contrarioresultB
. - Operadores Lógicos
-
Los operadores lógicos Y
&&
y Ó||
realizan una evaluación de circuito corto y luego devuelven el valor donde se detuvo (no necesariamente true/false). El operador lógico NOT!
convierte el operando a tipo booleano y devuelve el valor inverso. - Operador “Nullish coalescing”
-
El operador
??
brinda una forma de elegir el primer valor “definido” de una lista de variables. El resultado dea ?? b
esa
salvo que esta seanull/undefined
, en cuyo caso seráb
. - Comparaciones
-
Para verificar la igualdad
==
de valores de diferentes tipos, estos se convierten a número (exceptonull
yundefined
que son iguales entre sí y nada más), por lo que son iguales:alert( 0 == false ); // true alert( 0 == '' ); // true
Otras comparaciones también se convierten en un número.
El operador de igualdad estricta
===
no realiza la conversión: diferentes tipos siempre significan diferentes valores.Los valores
null
yundefined
son especiales: son iguales==
el uno al otro y no son iguales a nada más.Las comparaciones mayor/menor comparan las cadenas carácter por carácter, los demás tipos de datos se convierten a número.
- Otros operadores
-
Hay algunos otros, como un operador de coma.
Más en: Operadores básicos, matemáticas, Comparaciones, Operadores Lógicos, Operador Nullish Coalescing '??'.
Bucles
-
Cubrimos 3 tipos de bucles:
// 1 while (condition) { ... } // 2 do { ... } while (condition); // 3 for(let i = 0; i < 10; i++) { ... }
-
La variable declarada en el bucle
for(let...)
sólo es visible dentro del bucle. Pero también podemos omitir ellet
y reutilizar una variable existente. -
Directivas
break/continue
permiten salir de todo el ciclo/iteración actual. Use etiquetas para romper bucles anidados.
Detalles en: Bucles: while y for.
Más adelante estudiaremos más tipos de bucles para tratar con objetos.
La construcción “switch”
La construcción “switch” puede reemplazar múltiples revisiones con if
. “switch” utiliza ===
(comparación estricta).
Por ejemplo:
let age = prompt('¿Su Edad?', 18);
switch (age) {
case 18:
alert("No funciona"); // el resultado de la petición es un string, no un número
case "18":
alert("¡Funciona!");
break;
default:
alert("Todo valor que no sea igual a uno de arriba");
}
Detalles en: La sentencia "switch".
Funciones
Cubrimos tres formas de crear una función en JavaScript:
-
Declaración de función: la función en el flujo del código principal
function sum(a, b) { let result = a + b; return result; }
-
Expresión de función: la función en el contexto de una expresión
let sum = function(a, b) { let result = a + b; return result; };
-
Funciones de flecha:
// la expresión en el lado derecho let sum = (a, b) => a + b; // o sintaxis multilínea { ... }, aquí necesita return: let sum = (a, b) => { // ... return a + b; } // sin argumentos let sayHi = () => alert("Hello"); // con un único argumento let double = n => n * 2;
- Las funciones pueden tener variables locales: son aquellas declaradas dentro de su cuerpo. Estas variables solo son visibles dentro de la función.
- Los parámetros pueden tener valores predeterminados:
function sum(a = 1, b = 2) {...}
. - Las funciones siempre devuelven algo. Si no hay
return
, entonces el resultado esundefined
.
Más: ver Funciones, Funciones Flecha, lo básico.
Más por venir
Esa fue una breve lista de características de JavaScript. Por ahora solo hemos estudiado lo básico. Más adelante en el tutorial encontrará más características especiales y avanzadas de JavaScript.
Comentarios
<code>
, para varias líneas – envolverlas en la etiqueta<pre>
, para más de 10 líneas – utilice una entorno controlado (sandbox) (plnkr, jsbin, codepen…)