const declaration has many use cases in modern JavaScript.
Some developers prefer to assign all their variables using const by default, unless they know they will need to reassign the value. Only in that case, they use let.
However, it is important to understand that objects (including arrays and functions) assigned to a variable using const are still mutable. Using the const declaration only prevents reassignment of the variable identifier.
"use strict";As you can see, you can mutate the object
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] itself and the variable s will still point to the altered array [5, 6, 45]. Like all arrays, the array elements in s are mutable, but because const was used, you cannot use the variable identifier s to point to a different array using the assignment operator.
const s = [5, 7, 2]. Change the array to [2, 5, 7] using various element assignment.
const keyword.
    testString: getUserInput => assert(getUserInput('index').match(/const/g), 'Do not replace const keyword.');
  - text: s should be a constant variable (by using const).
    testString: getUserInput => assert(getUserInput('index').match(/const\s+s/g), 's should be a constant variable (by using const).');
  - text: Do not change the original array declaration.
    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 should be equal to [2, 5, 7].
    testString: assert.deepEqual(s, [2, 5, 7], 's should be equal to [2, 5, 7].');
```