const
имеет много вариантов использования в современном JavaScript. Некоторые разработчики предпочитают назначать все свои переменные, используя const
по умолчанию, если только они не знают, что им нужно будет переназначить это значение. Только в этом случае они используют let
. Однако важно понимать, что объекты (включая массивы и функции), назначенные переменной с использованием const
, по-прежнему изменяемы. Использование объявления const
только предотвращает переназначение идентификатора переменной. «использовать строгую»;Как вы можете видеть, вы можете самостоятельно мутировать объект
const s = [5, 6, 7];
s = [1, 2, 3]; // выдает ошибку, пытаясь назначить const
s [2] = 45; // работает так же, как и с объявленным массивом var или let
console.log (ы); // возвращает [5, 6, 45]
[5, 6, 7]
, а переменная s
все равно укажет на измененный массив [5, 6, 45]
. Как и все массивы, элементы массива в s
изменяемы, но поскольку используется const
, вы не можете использовать идентификатор переменной s
для указания на другой массив с использованием оператора присваивания. const s = [5, 7, 2]
. Измените массив на [2, 5, 7]
используя различные назначения элементов. const
.
testString: 'getUserInput => assert(getUserInput("index").match(/const/g), "Do not replace const
keyword.");'
- text: s
должна быть постоянной переменной (используя const
).
testString: 'getUserInput => assert(getUserInput("index").match(/const\s+s/g), "s
should be a constant variable (by using const
).");'
- text: Не изменяйте оригинальное объявление массива.
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
должно быть равно [2, 5, 7]
.'
testString: 'assert.deepEqual(s, [2, 5, 7], "s
should be equal to [2, 5, 7]
.");'
```