26 técnicas de optimización de JavaScript

La vida de un desarrollador siempre es aprender cosas nuevas. Como desarrollador front-end, debemos conocer algunas técnicas para que nuestro código sea más elegante y funcione más fácilmente.

Tal vez haya estado desarrollando JavaScript durante mucho tiempo, pero a veces es posible que no utilice las últimas funciones que pueden resolver el problema sin la necesidad de resolver o escribir algún código adicional. Estas técnicas pueden ayudarlo a escribir código JavaScript limpio y optimizado.

1. Juicios de múltiples condiciones

// long
if( x === 'a' || x === 'b' || x === 'c' || x === 'd'){
  // logic
}

// short
if(['a', 'b', 'c', 'd'].includes(x)){
  // logic
}

2. Operador ternario

Cuando solo usamos algunos juicios condicionales if / esle, podemos simplemente usar operadores ternarios para lograr.

Si hay muchos pares de juicios de condición if / else, no se recomienda usar

// long
let flag
if(x > 10){
  flag = true
}else {
  flag = false
}

// short
let flag = x > 10 ? true : false

3. Declaración de variable

Cuando queremos declarar dos variables que tienen un valor común o un tipo común, esta forma abreviada se puede utilizar

// long
let var1
let var2 = 1

// short
let var1, var2 = 1

4. Marque vacío / indefinido y asigne un valor predeterminado

Cuando necesitamos crear una nueva variable, a veces necesitamos verificar si la variable referenciada por su valor es nula o indefinida, podemos considerar la siguiente implementación:

// long
if(test1 !== null || test1 !== undefined || test1 !== ""){
  let test2 = test1;
}else {
  let test2 = ''
}

// short
let test2 = test1 || ''

5. Asignar valores a múltiples variables

Este método es muy útil cuando se trata de múltiples variables y queremos asignar diferentes valores a diferentes variables.

//long 
let test1, test2, test3;
test1 = 1;
test2 = 2;
test3 = 3;

//Short 
let [test1, test2, test3] = [1, 2, 3];

6. Taquigrafía para operador de asignación

Nos ocupamos de muchos operadores aritméticos en programación. Esta es una de las técnicas útiles para asignar operadores a variables de JavaScript.

// long
test1 = test1 + 1;
test2 = test2 - 1;
test3 = test3 * 20;

// short
test1++;
test2--;
test3 *= 20;

7. Juicio de la verdad

// long
if (test1 === true)

// short
if (test1)

8. Operación Y / O de múltiples condiciones

//long 
if (test1) {
 callMethod(); 
} 

//short 
test1 && callMethod();

9. forEath

// long
for (var i = 0; i < testList.length; i++)

// short
testList.forEach(item => console.log(item))

10. Compare los valores devueltos

// long
let test;
function checkReturn() {
    if (!(test === undefined)) {
        return test;
    } else {
        return callMe('test');
    }
}
var data = checkReturn();
console.log(data); //output test
function callMe(val) {
    console.log(val);
}

// short
function checkReturn() {
    return test || callMe('test');
}

11. Funciones de flecha

//long 
function add(a, b) { 
   return a + b; 
} 
//short 
const add = (a, b) => a + b;

12. Llamadas de función breves

// long
function test1() {
  console.log('test1');
};
function test2() {
  console.log('test2');
};
var test3 = 1;
if (test3 == 1) {
  test1();
} else {
  test2();
}

// short
(test3 === 1? test1:test2)();

13. cambiar

Podemos guardar la condición en el objeto de valor-clave y usarla de acuerdo con la condición.

// long
switch (data) {
  case 1:
    test1();
  break;

  case 2:
    test2();
  break;

  case 3:
    test();
  break;
  // And so on...
}

// short
var data = {
  1: test1,
  2: test2,
  3: test
};

data[something] && data[something]();

14. Parámetros predeterminados

//long
function add(test1, test2) {
  if (test1 === undefined)
    test1 = 1;
  if (test2 === undefined)
    test2 = 2;
  return test1 + test2;
}

//short
add = (test1 = 1, test2 = 2) => (test1 + test2);
add() //output: 3

15. El parámetro debe pasarse y verificarse

// long
function hello(obj){
  let {name, age} = obj
  if(!name){
    console.warn('name is null, pls check!')
    return ''
  }
  if(!age){
    console.warn('age is null, pls check!')
    return ''
  }
  return `${name}: ${age}`
}

// short
function hello(obj){
  let {name = required('name'), age = required('age')} = obj
  return `${name}: ${age}`
}

function required(key){
  console.warn(`${key} is null, pls check!')
}

16. Operador de propagación

//long
const data = [1, 2, 3];
const test = [4 ,5 , 6].concat(data);

//short
const data = [1, 2, 3];
const test = [4 ,5 , 6, ...data];
console.log(test); // [ 4, 5, 6, 1, 2, 3]

Para la clonación, también podemos usar el operador de propagación.

//long
const test1 = [1, 2, 3];
const test2 = test1.slice()

//short
const test1 = [1, 2, 3];
const test2 = [...test1];

17. Cadena de plantilla

Si está cansado de usar + en una sola cadena para conectar múltiples variables, puede considerar esta manera

//long
const welcome = 'Hi ' + user + ' ' + name + '.'

//short
const welcome = `Hi ${user} ${name}`;

18. Asignación de atributos de objeto

let test1 = 'a'; 
let test2 = 'b';
//Long
let obj = {test1: test1, test2: test2}; 

//short 
let obj = {test1, test2};

19. Convierte cadena en número

//Long
let test1 = parseInt('123'); 
let test2 = parseFloat('12.3'); 

//Short
let test1 = +'123'; 
let test2 = +'12.3';

20. Array.find

Cuando tenemos una matriz de objetos y queremos encontrar objetos específicos basados ​​en las propiedades del objeto, el método de búsqueda es realmente útil.

const data = [{
        type: 'test1',
        name: 'abc'
    },
    {
        type: 'test2',
        name: 'cde'
    },
    {
        type: 'test1',
        name: 'fgh'
    },
]
// long
function findtest1(name) {
    for (let i = 0; i < data.length; ++i) {
        if (data[i].type === 'test1' && data[i].name === name) {
            return data[i];
        }
    }
}

//shorthand
filteredData = data.find(data => data.type === 'test1' && data.name === 'fgh');
console.log(filteredData); 

21. Juicio de condiciones múltiples

Si tenemos un código para verificar el tipo y necesitamos llamar a diferentes métodos basados ​​en el tipo, podemos optar por usar varios else if o switch, ¿hay uno mejor?

// long
if (type === 'test1') {
  test1();
}
else if (type === 'test2') {
  test2();
}
else if (type === 'test3') {
  test3();
}
else if (type === 'test4') {
  test4();
} else {
  throw new Error('Invalid value ' + type);
}

// short
const types = {
  test1: test1,
  test2: test2,
  test3: test3,
  test4: test4
};

let func = types[type];
(!func) && throw new Error('Invalid value ' + type); func();

22. Búsqueda de índice

Cuando iteramos la matriz para encontrar un valor específico, usamos indexOf()métodos, ¿y si encontramos un método mejor? Miremos este ejemplo.

//long
if(arr.indexOf(item) > -1) { // item found 
}
if(arr.indexOf(item) === -1) { // item not found
}

//short
if(~arr.indexOf(item)) { // item found
}
if(!~arr.indexOf(item)) { // item not found
}

El ~operador bit a bit devolverá un valor real distinto de -1. Revertir es ~tan simple como hacerlo . Además, también podemos utilizar include()funciones:

if (arr.includes(item)) { 
// true if the item found
}

24. Object.entries ()

Esta característica ayuda a convertir un objeto en una matriz de objetos.

const data = { test1: 'abc', test2: 'cde', test3: 'efg' };
const arr = Object.entries(data);
console.log(arr);
/** ouput

[ [ 'test1', 'abc' ],
  [ 'test2', 'cde' ],
  [ 'test3', 'efg' ]
]

**/

24. Object.values ​​()

const data = { test1: 'abc', test2: 'cde' };
const arr = Object.values(data);
console.log(arr);
/** Output:

[ 'abc', 'cde']

**/

25. Repite una cadena varias veces

Para repetir los mismos caracteres una y otra vez, podemos usar un ciclo for y agregarlos al mismo ciclo, pero ¿y si tenemos un método abreviado?

//long 
let test = ''; 
for(let i = 0; i < 5; i ++) { 
  test += 'test '; 
} 
console.log(str); // test test test test test 

//short 
'test '.repeat(5);

26. Encuentra los valores máximo y mínimo en una matriz.

const arr = [1, 2, 3]; 
Math.max(…arr); // 3
Math.min(…arr); // 1

Este artículo es un extracto : www.toutiao.com/i6915617290 ...

Supongo que te gusta

Origin blog.csdn.net/hugo233/article/details/112758064
Recomendado
Clasificación