const
tiene muchos casos de uso en JavaScript moderno.
Algunos desarrolladores prefieren asignar todas sus variables usando const
de forma predeterminada, a menos que sepan que deberán reasignar el valor. Solo en ese caso, usan let
.
Sin embargo, es importante comprender que los objetos (incluidas las matrices y las funciones) asignados a una variable que usa const
todavía son mutables. El uso de la declaración const
solo evita la reasignación del identificador de variable.
"use strict";Como puede ver, puede mutar el objeto
const s = [5, 6, 7];
s = [1, 2, 3]; // throws error, trying to assign a const
s[2] = 45; // works just as it would with an array declared with var or let
console.log(s); // returns [5, 6, 45]
[5, 6, 7]
sí mismo y la variable s
seguirá apuntando a la matriz alterada [5, 6, 45]
. Al igual que todas las matrices, los elementos de la matriz en s
son mutables, pero debido a que se utilizó const
, no puede usar el identificador de la variable s
para apuntar a una matriz diferente mediante el operador de asignación.
const s = [5, 7, 2]
. Cambie la matriz a [2, 5, 7]
usando varias asignaciones de elementos.
const
.
testString: 'getUserInput => assert(getUserInput("index").match(/const/g), "Do not replace const
keyword.");'
- text: s
debe ser una variable constante (usando const
).
testString: 'getUserInput => assert(getUserInput("index").match(/const\s+s/g), "s
should be a constant variable (by using const
).");'
- text: No cambie la declaración original de la matriz.
testString: 'getUserInput => assert(getUserInput("index").match(/const\s+s\s*=\s*\[\s*5\s*,\s*7\s*,\s*2\s*\]\s*;?/g), "Do not change the original array declaration.");'
- text: ' s
debe ser igual a [2, 5, 7]
.'
testString: 'assert.deepEqual(s, [2, 5, 7], "s
should be equal to [2, 5, 7]
.");'
```