Skip to content

5 trucos para optimizar el rendimiento en Javascript

Published: at 03:22 PM

Truco 1: Minimizar el uso de variables globales

El uso excesivo de variables globales puede afectar negativamente el rendimiento de tu código JavaScript. Las variables globales se almacenan en el objeto global y están disponibles en todo tu código, lo que significa que pueden ser accedidas y modificadas desde cualquier parte de tu aplicación. Esto puede aumentar la complejidad y disminuir la legibilidad de tu código.

Para evitar este problema, es recomendable minimizar el uso de variables globales en tu código JavaScript. En su lugar, utiliza variables locales o pasalas como parámetros a tus funciones. De esta manera, limitas el alcance de tus variables y haces que sea más fácil razonar sobre tu código.

Aquí tienes un ejemplo de cómo reducir el uso de variables globales en tu código JavaScript:

// Variable global
var nombre = "Juan";

function saludar() {
  // Variable local
  var saludo = "Hola";

  console.log(saludo + " " + nombre);
}

saludar();

En este ejemplo, la variable nombre es una variable global y está disponible en todo el código. La variable saludo es una variable local y sólo está disponible dentro de la función saludar(). Al limitar el alcance de la variable saludo, mejoramos la legibilidad y mantenibilidad de nuestro código.

Truco 2: Utilizar variables locales para evitar el reevaluado de elementos del DOM

Cuando se trabaja con elementos del DOM en JavaScript, es importante tener en cuenta que acceder a ellos puede ser costoso en términos de rendimiento. Cada vez que se accede a un elemento del DOM, el navegador debe recorrer el árbol de elementos para encontrarlo, lo que puede ser muy lento.

Una forma de mejorar el rendimiento es almacenar los elementos del DOM en variables locales. De esta manera, se evita tener que recorrer el árbol de elementos cada vez que se accede a ellos. En lugar de eso, se accede a la variable local, lo que es mucho más rápido.

// Ejemplo de código
// Acceder a un elemento del DOM varias veces sin almacenarlo en una variable local
for (let i = 0; i < 1000; i++) {
  document.getElementById("mi-elemento").style.color = "red";
}

// Almacenar el elemento del DOM en una variable local para acceder a él más rápido
const miElemento = document.getElementById("mi-elemento");
for (let i = 0; i < 1000; i++) {
  miElemento.style.color = "red";
}

Como se puede ver en el ejemplo de código anterior, al acceder al elemento del DOM varias veces sin almacenarlo en una variable local, se está recorriendo el árbol de elementos cada vez. En cambio, al almacenar el elemento del DOM en una variable local, se accede a él directamente y se evita el recorrido del árbol de elementos.

Este truco puede ser especialmente útil en situaciones en las que se accede a un mismo elemento del DOM varias veces, como en ciclos o eventos de repetición. Almacenar los elementos del DOM en variables locales puede ayudar a reducir el tiempo de procesamiento y mejorar el rendimiento de la aplicación.

Espero que este truco te sea útil para optimizar el rendimiento de tus aplicaciones JavaScript. ¡Prueba a utilizarlo y comprueba la diferencia de velocidad!

Truco 3: Evitar el uso de bucles anidados

El uso de bucles anidados puede hacer que tu código JavaScript sea más lento. Si tienes bucles anidados, especialmente bucles for anidados, es probable que estés haciendo que tu código sea menos eficiente.

Una técnica común para evitar los bucles anidados es utilizar el método reduce() en lugar de un bucle for anidado. reduce() permite combinar los elementos de una matriz en un solo valor mediante una función reductora.

Veamos un ejemplo de código:

// Ejemplo de bucles for anidados
const numeros = [
  [1, 2, 3],
  [4, 5, 6],
  [7, 8, 9],
];
let suma = 0;

for (let i = 0; i < numeros.length; i++) {
  for (let j = 0; j < numeros[i].length; j++) {
    suma += numeros[i][j];
  }
}

console.log(suma); // Salida: 45

// Ejemplo de uso de reduce()
const numeros = [
  [1, 2, 3],
  [4, 5, 6],
  [7, 8, 9],
];

const sumaInterna = (acumuladorInterno, valorActualInterno) => {
  return acumuladorInterno + valorActualInterno;
};

const suma = numeros.reduce((acumulador, valorActual) => {
  return acumulador + valorActual.reduce(sumaInterna, 0);
}, 0);

console.log(suma); // Salida: 45

En el ejemplo anterior, utilizamos el método reduce() para calcular la suma de todos los elementos de una matriz anidada en lugar de utilizar bucles for anidados. La función reductora recorre cada elemento de la matriz y los suma en el acumulador.

Si tienes que trabajar con matrices grandes, evita los bucles anidados siempre que sea posible. Utiliza otras técnicas para reducir el número de bucles y mejorar el rendimiento de tu código.

Truco 4: Utilizar funciones en lugar de bucles para manipular arrays

Al manipular arrays en JavaScript, es común utilizar bucles para recorrerlos y realizar operaciones en sus elementos. Sin embargo, en muchas ocasiones, es posible utilizar funciones de alto nivel que realizan estas operaciones de forma más eficiente.

Un ejemplo común es el uso de forEach() en lugar de un bucle for para recorrer un array y realizar una operación en cada elemento. La función forEach() es más legible y fácil de usar que un bucle for, y además suele ser más rápida en la mayoría de los casos.

// Ejemplo con bucle for
const numeros = [1, 2, 3, 4, 5];
for (let i = 0; i < numeros.length; i++) {
  numeros[i] = numeros[i] * 2;
}

// Ejemplo con forEach()
const numeros = [1, 2, 3, 4, 5];
numeros.forEach((numero, index, array) => {
  array[index] = numero * 2;
});

En este ejemplo, tanto el bucle for como forEach() multiplican cada elemento del array numeros por 2. Sin embargo, forEach() es más conciso y fácil de leer que el bucle for, y además es más eficiente en términos de rendimiento.

Otras funciones de alto nivel que pueden ser útiles para manipular arrays incluyen map(), filter(), reduce(), some(), y every(). Estas funciones se utilizan comúnmente en lugar de bucles para realizar operaciones más complejas en arrays.

En general, al utilizar funciones en lugar de bucles para manipular arrays, se puede mejorar el rendimiento del código y hacerlo más legible y fácil de mantener.

Truco 5: Utilizar operaciones de incremento y decremento en lugar de operaciones de suma y resta

Otro truco sencillo para mejorar el rendimiento de tu código en JavaScript es utilizar operaciones de incremento y decremento en lugar de operaciones de suma y resta. Esto se debe a que las operaciones de incremento y decremento son más eficientes en términos de velocidad de ejecución que las operaciones de suma y resta.

Por ejemplo, en lugar de escribir:

let i = 0;
i = i + 1;

Puedes escribir:

let i = 0;
i++;

Y en lugar de escribir:

let i = 0;
i = i - 1;

Puedes escribir:

let i = 0;
i--;

Estas operaciones de incremento y decremento son especialmente útiles en bucles y otras estructuras de control de flujo que se ejecutan muchas veces. Al utilizar operaciones de incremento y decremento en lugar de operaciones de suma y resta, puedes optimizar el rendimiento de tu código y hacer que se ejecute más rápido.