const
tem muitos casos de uso no JavaScript moderno. Alguns desenvolvedores preferem atribuir todas as variáveis usando const
por padrão, a menos que saibam que precisarão reatribuir o valor. Apenas nesse caso, eles usam let
. No entanto, é importante entender que objetos (incluindo matrizes e funções) atribuídos a uma variável usando const
ainda são mutáveis. A utilização da declaração const
impede apenas a reatribuição do identificador de variáveis. "use strict";Como você pode ver, você pode alterar o próprio objeto
const s = [5, 6, 7];
s = [1, 2, 3]; // lança erro, tentando atribuir um const
s [2] = 45; // funciona exatamente como faria com uma matriz declarada com var ou let
console.log (s); // retorna [5, 6, 45]
[5, 6, 7]
e a variável s
ainda apontará para a matriz alterada [5, 6, 45]
. Como todas as matrizes, os elementos da matriz em s
são mutáveis, mas porque const
foi usado, você não pode usar o identificador variável s
para apontar para uma matriz diferente usando o operador de atribuição. const s = [5, 7, 2]
. Altere a matriz para [2, 5, 7]
usando várias atribuições de elementos. const
.
testString: 'getUserInput => assert(getUserInput("index").match(/const/g), "Do not replace const
keyword.");'
- text: s
deve ser uma variável constante (usando const
).
testString: 'getUserInput => assert(getUserInput("index").match(/const\s+s/g), "s
should be a constant variable (by using const
).");'
- text: Não altere a declaração original da 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
deve ser igual a [2, 5, 7]
.'
testString: 'assert.deepEqual(s, [2, 5, 7], "s
should be equal to [2, 5, 7]
.");'
```