Condicionales
Hasta ahora hemos visto código que se ejecuta línea a línea, una detrás de otra. Pero a veces se hace necesario romper esa secuencia y crear ramas que nos permitan tomar diferentes caminos en el código dependiendo de ciertas condiciones.
Por ejemplo, imagina cómo podríamos hacer un programa que nos diga si un número es mayor o menor a diez. Si es mayor a 10 debería imprimir una cosa, pero si es menor debería imprimir otra.
A este concepto se le conoce como condicionales y su sintaxis es la siguiente:
La condición puede ser cualquier expresión que evalúa a verdadero (true
) o falso (false
). Crea un archivo llamado conditionals.js
y agrega el siguiente contenido:
Nota: Las líneas que terminan con un corchete ({
o }
) no se les agrega punto y coma (;).
Ejecúta el archivo desde la consola, deberías ver lo siguiente:
No importa cuántas veces ejecutes este archivo, el resultado siempre será el mismo.
Ahora probemos con falso (false
) en vez de verdadero (true
):
Ejecútalo. Esta vez nunca debería imprimir "Hola mundo", no importa cuantas veces lo ejecutes.
En vez de utilizar true
o false
como condición, podemos utilizar una expresión que evalúe a true
o false
.
El resultado al ejecutarlo debería ser:
Prueba ahora con 1 == 2
, 1 < 6
y 8 < 6
en la condición y fíjate que tenga sentido.
Ahora que ya sabes cómo funciona los condicionales (muchos los llamamos los ifs) crea un programa en un archivo llamado number.js
que imprima "El número es menor a 10" solo si el número que está almacenado en la variable num
es menor a 10:
Si lo ejecutas te debería aparecer lo siguiente:
Ahora vamos a modificar el programa para que, además de imprimir "El número es menor a 10" si el número es menor a 10, también imprima "El número es igual o mayor a 10" si el número es igual o mayor a 10. Podemos utilizar otro condicional debajo del que ya teníamos:
Ejecuta el programa e ingresa un número menor a 10, después un número mayor a 10, y por último 10. Verifica que el resultado sea el esperado.
De lo contrario (else)
Lo único que necesitas para hacer condicionales es el if
. Pero existen dos atajos que te van a permitir escribir código más corto.
El primer atajo es el else
, que significa "de lo contrario" en Inglés. El else
nos permite definir el código que se debe ejecutar si el if
no se cumple, es decir si la condición evalúa a falso. La sintaxis es la siguiente:
Podemos modificar el programa anterior, que nos dice si el número almacenado en la variable num
es menor a 10, o si es mayor o igual, con un else
.
Más corto y si lo ejecutas debería funcionar igual.
Condiciones anidadas
Ahora imagina que queremos modificar este programa para que en vez de imprimir "El número es igual o mayor a 10", imprima "El número es igual a 10" o "El número es mayor a 10" dependiendo si el número es igual 10 o mayor a 10 respectivamente.
En JavaScript (y en la mayoría de lenguajes de programación) es posible anidar condicionales, así que una posible solución sería la siguiente:
Prúebalo con un número menor a 10, otro mayor a 10 y con 10. Te debería aparecer "El número es menor a 10", "El número es mayor a 10" y "El número es igual a 10" respectivamente.
De lo contrario, si (else if)
En general, es preferible no tener que anidar condicionales porque son difíciles de leer y entender. Otro atajo que nos ofrece JavaScript para los condicionales es el else if
, que significa "De lo contrario, si ..." en Inglés. La sintaxis es la siguiente:
Puedes definir tantos else if
como desees. El else
es opcional.
Modifiquemos nuestro ejemplo anterior y en vez de utilizar condiciones anidadas, utilicemos else if
:
Lo más importante de entender en este código es que el programa sólo va a entrar a una de estas ramas. Por ningún motivo va a entrar a dos de ellas. Si la condición del primer if
se cumple, el programa ejecuta el código que esté en ese bloque y después salta hasta después del else
para continuar con el resto del programa o terminar.
Si la condición del primer if
no se cumple, pero la del else if
sí se cumple, el programa ejecuta el código de ese bloque y salta hasta después del else
para continuar con el resto del programa o terminar.
Condiciones compuestas
Imagina que queremos escribir un programa que imprima "El número está entre 10 y 20" si el valor de una variable está efectivamente entre 10 y 20. ¿Cómo te imaginas que lo podríamos solucionar?
Una opción es usar condiciones anidadas, de esta forma:
Sin embargo, cómo decíamos antes, leer condiciones anidadas es difícil y, en lo posible, es mejor evitarlas. En cambio, podemos utilizar los operadores lógicos y (&&
) y ó (||
) para crear condiciones compuestas. El ejemplo anterior lo podemos mejorar con y:
Lo que estamos diciendo con este código es: si el número es mayor o igual a 10 y menor o igual 20 entonces imprima "El número está entre 10 y 20". Fíjate que a cada lado del &&
hay una expresión que evalúa a verdadero o falso: num >= 10
y num <= 20
.
Imagina ahora que necesitamos escribir un programa que imprima "Excelente elección" cuando el valor de una variable sea "rojo" o "negro" únicamente:
Pensando como un programador
Vamos a jugar un juego llamado Verdadero o Falso. Yo digo una afirmación y tu debes reponder si es verdadera o falsa. Trata de no mirar las respuestas debajo. Después comparas:
La Tierra gira alrededor del sol. (¿Verdadero o falso?)
Paris es la capital de Estados Unidos.
La Tierra gira alrededor del sol y los leones son animales.
Paris es la capital de Estados Unidos y los leones son animales.
La Tierra gira alrededor de Marte y los perros hablan Español.
Los leones son animales o la Tierra gira alrededor del sol.
Paris es la capital de Estados Unidos o los leones son animales.
El planeta tierra gira alrededor de Marte o los perros hablan Español.
Las respuestas son las siguientes:
Verdadero.
Falso.
Verdadero.
Falso.
Falso.
Verdadero.
Verdadero.
Falso.
Cuando utilizamos y las dos expresiones deben ser verdaderas para que el resultado sea verdadero. Cuando utilizamos o cualquiera de las dos expresiones puede ser verdadera para que el resultado sea verdadero.
Evaluando expresiones booleanas
Volvamos a jugar el juego, pero en vez de utilizar frases, utilicemos expresiones booleanas. Debes decidir si cada una de las siguientes expresiones es verdadera o falsa (true
o false
):
true
false
1 < 1
2 != 3
1 < 1 && 2 != 3
Copia y pega cada expresión en la consola de Node.js para conocer las respuestas.
Analicemos la última expresión: 1 < 1 && 2 != 3
. ¿Cómo podemos saber si es verdadera o falsa?
El primer paso es reemplazar cada lado de la expresión. 1 < 1
es false
y 2 != 3
es true
. Quedaría:
false && true
Recuerda que para que una expresión con y (&&
) sea verdadera, cada lado tiene que ser verdadero. Sin embargo, podemos hacer una tabla con todas las combinaciones entre verdadero y falso que podamos usar como referencia más adelante:
Fíjate que el resultado solo es true
cuando los dos lados del &&
son true
.
Hagamos lo mismo para el ó (||
):
Con el ó cualquiera de los lados puede ser true
para que el resultado sea true
.
A estas tablas se les conoce como Tablas de Verdad.
Hagamos algunos ejercicios. Decide si las siguientes expresiones evalúan a true
o false
. Primero reemplaza cada lado del &&
o el ||
y luego utiliza las tablas de verdad:
"hola" == "hola" && 1 < 2
true && 5 != 5
1 == 1 || 2 != 1
Revisa tu respuesta evaluando cada expresión en la consola de Node.js.
Podemos negar cualquier expresión booleana anteponiendo un signo de exclamación (!
). Por ejemplo:
!true
esfalse
!false
estrue
De hecho, esa es la tabla de verdad de la negación. Intenta los siguientes ejercicios. Primero reemplaza lo que está entre paréntesis y luego aplica la tabla de verdad de la negación:
!(1 === 1)
!(2 <= 3)
!(true && 5 !== 5)
!(1 < 1 && 2 !== 3)
El proceso para solucionar cualquier expresión booleana, sin importar qué tan compleja sea, es el siguiente:
Evalúa los operadores de igualdad (
<
,>
,===
,!==
etc).Evalúa los
&&
y||
que esten dentro de paréntesis.Evalúa las negaciones (
!
).Evalúa cualquier
&&
y||
que falte.
Hagamoslo juntos. Intentemos evaluar la siguiente expresión booleana:
Evaluar los operadores de igualdad:
Evaluar los
&&
y||
que estén dentro de paréntesis:Evaluar las negaciones:
Evaluar cualquier
&&
y||
que falte:
Inténtalo tu. Decide si las siguientes expresiones evalúan a true
o false
:
!(5 === 5) && 8 !== 8
("gut" === "ikk" && 26 > 30) || ("gut" === "gut" && 26 > 10)
!("testing" == "testing" && !(5 > 8))
Evalúate
¿Cuál es la syntaxis de un
if
(sinelse
oelse if
)?¿En qué caso se ejecuta el código que está dentro del
if
?¿En qué caso se ejecuta el código que está dentro del
else
?¿Cuántos
else
pueden existir en un condicional?¿Cuántos
else if
pueden existir en un condicional?¿Qué problema tiene el siguiente código?
¿Cuál es el resultado de evaluar
!(1 == 1)
?¿Cuál es el resultado de evaluar
3 != 4 && !("pedro" === "juan" || 26 > 10)
?¿Qué imprimiría el siguiente código?
Last updated