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

JavaScript: Llamada a una función - expresión

En programación, una expresión es algo que devuelve un resultado que se puede utilizar. Ya sabemos bastante sobre expresiones y los principios de su construcción. Las operaciones matemáticas (suma, resta), así como las operaciones de cadenas (concatenación), - todas estas son expresiones:

1 + 5 * 3;
'Hex' + 'Let';
// Las variables pueden ser parte de una expresión
rate * 5;

La característica de las expresiones es que devuelven un resultado que se puede asignar a una constante o mostrar en pantalla. Por ejemplo:

// Aquí la expresión es 1 + 5
const sum = 1 + 5;
console.log(1 + 5);

Pero no todo en programación es una expresión. La declaración de una variable es una instrucción; no puede ser parte de una expresión. Es decir, este código dará un error:

// Código sin sentido que no funcionará
10 + const sum = 1 + 5;

¿Por qué es importante saber esto? Como verás más adelante, las expresiones se pueden combinar para obtener un comportamiento más complejo en lugares inesperados y de formas inesperadas. Entenderás mejor cómo se pueden combinar las partes del código para obtener el resultado deseado.

Hablemos de las funciones. ¿Una llamada a una función es una expresión o no? Sabemos que las funciones devuelven un resultado, por lo tanto, sí, son expresiones. De esto se deduce automáticamente muchas cosas interesantes. Por ejemplo, podemos usar una llamada a una función directamente en operaciones matemáticas. Así es como se puede obtener el índice del último carácter en una palabra:

import { length } from 'hexlet-basics/string';

const name = 'JavaScript';
// Los índices comienzan desde cero
// ¡Llamada al método y resta juntos!
const lastIndex = length(name) - 1;
console.log(lastIndex); // 9

En este código no hay una nueva sintaxis. Solamente hemos combinado partes conocidas basándonos en su naturaleza. Podemos ir aún más lejos:

console.log(length(name) - 1); // 9

Todo esto es válido para cualquier función, por ejemplo, las funciones de cadenas:

import { length } from 'hexlet-basics/string';

const name = 'JavaScript';
// Se utiliza interpolación
console.log(`Último carácter: ${name[length(name) - 1]}`);
// 'Último carácter: t'

Tarea

Muestra en pantalla la primera y la última letra de la oración que está almacenada en la constante text, en el siguiente formato:

First: N
Last: t

Intenta crear solamente una constante en la que se almacene el texto necesario antes de imprimirlo en pantalla. En esta lección, estamos practicando la habilidad de construir una expresión compuesta.

¿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.

Definiciones

  • Expresión — una secuencia de acciones sobre datos que conduce a un resultado que se puede utilizar.


¿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