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

JavaScript: Incremento y decremento

Del lenguaje C a JavaScript se han trasladado dos operaciones: incremento ++ y decremento --, que se encuentran muy a menudo en combinación con bucles. Estas operaciones unarias aumentan y disminuyen en uno el número almacenado en una variable:

let i = 0;
i++; // 0
i++; // 1

i--; // 2
i--; // 1

Además de la forma posfija, también tienen una forma prefija:

let i = 0;
++i; // 1
++i; // 2

--i; // 1
--i; // 0

Parece que no hay ninguna diferencia entre las formas posfija y prefija. Pero aquí es donde empiezan las complicaciones.

A diferencia de todas las demás operaciones, que no tienen efectos secundarios y simplemente devuelven un nuevo valor, el incremento y el decremento no solo devuelven un valor, sino que también modifican el valor de la variable.

Al utilizar la notación prefija, primero se produce la modificación de la variable y luego se devuelve.

Al utilizar la notación posfija, ocurre lo contrario: se puede considerar que primero se devuelve y luego se modifica la variable.

Esta regla se aplica de la misma manera tanto al incremento como al decremento. Para simplificar, consideremos solamente el incremento:

let x = 5;

console.log(++x); // => 6
console.log(x);   // => 6

console.log(x++); // => 6
console.log(x);   // => 7

https://replit.com/@hexlet/js-basic-mutators

¿Qué está sucediendo aquí?

  1. Imprimimos en la pantalla ++x. Esto es un incremento prefijo, por lo que primero se incrementa el valor de la variable en 1, luego se devuelve el resultado y se imprime en la pantalla.
  2. Como el valor ha cambiado, console.log(x) imprime 6.
  3. Ahora imprimimos en la pantalla x++. Esto es un incremento posfijo, por lo que se devuelve el valor que tenía la variable antes de incrementarse en 1.
  4. Como el valor ha cambiado, console.log(x) imprime 7.

Esto se vuelve especialmente confuso cuando se inserta el incremento dentro de otras operaciones: x = i++ - 7 + --h. Es casi imposible entender este código, y su escritura debería considerarse una violación grave.

Por ejemplo, en JavaScript, el linter (un programa que verifica el código) comienza a mostrar advertencias tan pronto como encuentra el uso de incremento o decremento.

Recomendaciones de uso:

  • Nunca mezcle operaciones/funciones sin efectos secundarios con operaciones/funciones que sí los tienen en el mismo expresión.
  • Utilice el incremento y el decremento solo donde no haya diferencia entre la forma prefija y la forma posfija: por separado de todo, en su propia línea de código.

Tarea

Escriba una función makeItFunny() que reciba una cadena de texto y devuelva una copia de la cadena en la que cada elemento n-ésimo esté en mayúsculas. El valor de n se pasa como argumento a la función.

Para determinar cada elemento n-ésimo, se utilizará el operador de resto %. Piense en cómo se puede utilizar.

const text = 'I never look back';
// Cada tercer elemento
makeItFunny(text, 3); // 'I NevEr LooK bAck'
¿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

  • Efecto secundario — una acción que modifica el entorno externo (el entorno de ejecución). Por ejemplo, la impresión en pantalla o el envío de un correo electrónico.


¿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