JavaScript: Operador ternario
Echa un vistazo a la definición de una función que devuelve el valor absoluto de un número:
const abs = (number) => {
if (number >= 0) {
return number;
}
return -number;
};
abs(10); // 10
abs(-10); // 10
¿Se puede escribir de forma más concisa? Algo como return <respuesta dependiendo de la condición>
? Para eso, a la derecha de return
debe haber una expresión, pero if
es una instrucción, no una expresión.
En JavaScript existe una construcción que es similar a la estructura if-else, pero a la vez es una expresión. Se llama operador ternario.
El operador ternario es único en su tipo, ya que requiere tres operandos:
const abs = (number) => {
return number >= 0 ? number : -number;
};
El patrón general se ve así: <predicate> ? <expression on true> : <expression on false>
.
La versión abreviada de la función abs()
se ve así:
const abs = (number) => (number >= 0 ? number : -number);
Ten en cuenta los paréntesis alrededor del operador ternario. No son obligatorios, pero el linter recomienda encarecidamente usarlos para evitar ambigüedades.
Ahora reescribamos la función inicial getTypeOfSentence()
de manera similar:
Antes:
const getTypeOfSentence = (sentence) => {
const lastChar = sentence.slice(-1);
if (lastChar === '?') {
return 'question';
}
return 'normal';
};
Después:
const getTypeOfSentence = (sentence) => {
const lastChar = sentence.slice(-1);
return (lastChar === '?') ? 'question' : 'normal';
};
getTypeOfSentence('Hodor'); // normal
getTypeOfSentence('Hodor?'); // question
https://replit.com/@hexlet/js-basics-ternary-operator
Si recuerdas el poder de las expresiones, probablemente ya te hayas dado cuenta de que se puede anidar un operador ternario dentro de otro. No hagas esto :). Este tipo de código es difícil de leer y depurar, y es una mala práctica.
Tarea
Implementa la función convertText()
, que recibe una cadena de texto y, si la primera letra no está en mayúscula, devuelve la versión invertida de la cadena original. Si la primera letra está en mayúscula, la función devuelve la cadena sin cambios. Si se pasa una cadena vacía como argumento, la función debe devolver una cadena vacía.
Ejemplos de uso:
convertText('Hello'); // Hello
convertText('hello'); // olleh
// No olvides tener en cuenta la cadena vacía
convertText(''); // ''
Puedes invertir una cadena utilizando la función reverse()
. Debes pasar la cadena que deseas invertir como argumento:
const result = reverse('Hello!');
console.log(result); // => !olleH
Hay diferentes enfoques para resolver este problema. Es posible que necesites el método toUpperCase() y la capacidad de obtener un carácter de una cadena (por ejemplo, str[0]
).
Intenta escribir dos versiones de la función: una con un if-else normal y otra con un operador ternario.
Consejos
- Piensa en qué verificación debes hacer primero: si la primera letra es mayúscula o si la cadena está vacía. ¿Qué es más importante?
¿El ejercicio no pasa la prueba, qué debo hacer? 😶
Si te quedaste atascado, es el momento perfecto para hacer una pregunta en las "Discusiones".
* Asegúrate de incluir la salida de las pruebas. Sin ella, es casi imposible entender qué está mal, incluso si muestras tu código. Los programadores tienen dificultades para ejecutar el código en su mente, pero casi siempre es posible entender a dónde mirar a partir del error que recibiste.
Mi código funciona en mi entorno, pero no aquí 🤨
Las pruebas están diseñadas de manera que verifican la solución de diferentes maneras y con diferentes datos. A menudo, una solución funciona con ciertos datos de entrada pero no con otros. Para entender este punto, revisa la pestaña "Pruebas" y presta atención a los mensajes de error, que suelen contener pistas.
Mi código es diferente a la solución del profesor 🤔
Esto es normal 🙆. En programación, una tarea puede tener muchas soluciones diferentes. Si tu código pasa la prueba, cumple con los requisitos de la tarea.
En raras ocasiones, la solución puede estar ajustada para pasar las pruebas, pero esto suele ser evidente.
Leí la lección, pero no entendí nada 🙄
Crear materiales de aprendizaje comprensibles para todos es bastante difícil. Hacemos nuestro mejor esfuerzo, pero siempre hay margen para mejorar. Si encuentras material que no entiendes, describe el problema en las "Discusiones". Es ideal si puedes formular los aspectos que no entiendes en forma de preguntas. Por lo general, necesitamos unos días para hacer mejoras.
Por cierto, tú también puedes contribuir a mejorar los cursos: en la parte inferior hay un enlace al código fuente de las lecciones, que se puede modificar directamente en el navegador.
Consejos útiles
Definiciones
Operador ternario — Una forma de convertir una simple instrucción condicional en una expresión, por ejemplo,
number >= 0 ? number : -number
.