Curso gratuito de JavaScript. Regístrate para hacer un seguimiento de tu progreso →

JavaScript: Valores de retorno

Las funciones que definimos en las lecciones anteriores terminaban su ejecución imprimiendo datos en la pantalla:

const greeting = () => {
  console.log('Hello, Hexlet!');
};

Sin embargo, este tipo de funciones tienen un uso limitado, ya que no se puede utilizar el resultado de su ejecución en el programa. Vamos a ver esto en un ejemplo.

Tomemos la tarea de procesar direcciones de correo electrónico. Cuando un usuario se registra en un sitio web, puede ingresar su correo electrónico de diferentes maneras:

  • Añadiendo espacios en blanco al principio o al final _support@hexlet.io__
  • Usando letras en diferentes mayúsculas y minúsculas SUPPORT@hexlet.io

Si guardamos la dirección de correo electrónico en esta forma en la base de datos, es probable que el usuario no pueda iniciar sesión en el sitio web, ya que ingresará la dirección sin espacios y con letras en mayúsculas diferentes. Para evitar esto, es necesario preparar la dirección de correo electrónico antes de guardarla en la base de datos. Se debe convertir a minúsculas y eliminar espacios en blanco al principio y al final de la cadena. Esta tarea se puede resolver en un par de líneas de código:

const saveEmail = () => {
  // En realidad, el correo electrónico proviene de un formulario
  const email = '  SuppORT@hexlet.IO';
  // Eliminamos espacios en blanco al principio y al final
  const trimmedEmail = email.trim();
  const preparedEmail = trimmedEmail.toLowerCase();
  console.log(preparedEmail);
  // Aquí iría la escritura en la base de datos
};

Este código es posible gracias al retorno de valores. Los métodos trim() y toLowerCase() no imprimen nada en la pantalla (en la consola), sino que devuelven el resultado de su ejecución. Por lo tanto, podemos almacenar el resultado en constantes. Si en lugar de esto imprimieran en la pantalla, no podríamos asignar el resultado de su ejecución a una constante, lo cual es lo que ocurre con la función greeting() que se mostró anteriormente:

const message = greeting();
console.log(message); // => undefined

Cambiaremos la función greeting() para que en lugar de imprimir el mensaje, retorne el mensaje. Para lograrlo, debemos usar la palabra clave return en lugar de imprimir en la pantalla:

const greeting = () => {
  return 'Hello, Hexlet!';
};

return es una instrucción especial que toma la expresión que se encuentra a la derecha y la devuelve al código que llamó a la función. Tan pronto como JavaScript encuentra la instrucción return, la ejecución de la función se detiene.

// Ahora podemos usar el resultado de la función
const message = greeting();
console.log(message); // => Hello, Hexlet!
// Incluso podemos realizar acciones en el resultado
console.log(message.toUpperCase()); // => HELLO, HEXLET!

Cualquier código después de la instrucción return no se ejecuta:

const greetingWithCodeAfterReturn = () => {
  return 'Hello, Hexlet!';
  console.log('Nunca me ejecutaré');
};

Incluso si una función devuelve un valor, eso no limita la posibilidad de imprimir en la pantalla. Además de retornar valores, también podemos imprimir:

const greetingWithReturnAndPrinting = () => {
  console.log('Apareceré en la consola');
  return 'Hello, Hexlet!';
};

// Esto imprimirá el texto en la pantalla y también devolverá el valor
const message = greetingWithReturnAndPrinting ();

No solo se pueden retornar valores concretos. Dado que return funciona con expresiones, casi cualquier cosa puede estar a la derecha de él. Sin embargo, siempre es importante mantener el código legible:

const greeting = () => {
  const message = 'Hello, Hexlet!';
  return message;
};

En este ejemplo, no estamos retornando la variable en sí, sino el valor que contiene. A continuación, un ejemplo con cálculos:

const doubleFive = () => {
  // o return 5 + 5
  const result = 5 + 5;
  return result;
};

Pregunta de autocomprobación. ¿Qué devolverá la función run(), definida abajo, cuando se le llame?

// Definición
const run = () => {
  return 5;
  return 10;
};

// ¿Qué se imprimirá en la pantalla?
console.log(run());
Respuesta En la pantalla se imprimirá `5`.

https://replit.com/@hexlet/js-basics-functions-return

Tarea

Implementa la función sayHurrayThreeTimes(), que devuelve la cadena 'hurray! hurray! hurray!'.

const hurra = sayHurrayThreeTimes();
console.log(hurray); // => hurray! hurray! hurray!
¿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


¿Encontraste un error? ¿Quieres añadir algo? Las solicitudes de extracción son bienvenidas. https://codica.la/errores
Si te encuentras con dificultades y no sabes qué hacer, pregunta en nuestra gran y amigable comunidad