--- id: 587d7b8a367417b2b2512b4c title: Use Destructuring Assignment with the Rest Operator to Reassign Array Elements challengeType: 1 videoUrl: '' localeTitle: Назначение Destructuring с оператором Rest для переназначения элементов массива --- ## Description
В некоторых ситуациях, связанных с разрушением массива, мы могли бы захотеть собрать остальные элементы в отдельный массив. Результат аналогичен Array.prototype.slice() , как показано ниже:
const [a, b, ... arr] = [1, 2, 3, 4, 5, 7];
console.log (a, b); // 1, 2
console.log (обр); // [3, 4, 5, 7]
Переменные a и b принимают первое и второе значения из массива. После этого из-за присутствия оператора отдыха arr получает остальные значения в виде массива. Элемент rest работает корректно только как последняя переменная в списке. Как и в случае, вы не можете использовать оператор rest, чтобы поймать субарей, который не содержит последний элемент исходного массива.
## Instructions undefined ## Tests
```yml tests: - text: '' testString: 'assert(arr.every((v, i) => v === i + 3) && arr.length === 8,"arr should be [3,4,5,6,7,8,9,10]");' - text: '' testString: 'getUserInput => assert(getUserInput("index").match(/\[\s*\w*\s*,\s*\w*\s*,\s*...\w+\s*\]/g),"Destructuring should be used.");' - text: '' testString: 'getUserInput => assert(!getUserInput("index").match(/slice/g), "Array.slice() should not be used.");' ```
## Challenge Seed
```js const source = [1,2,3,4,5,6,7,8,9,10]; function removeFirstTwo(list) { "use strict"; // change code below this line arr = list; // change this // change code above this line return arr; } const arr = removeFirstTwo(source); console.log(arr); // should be [3,4,5,6,7,8,9,10] console.log(source); // should be [1,2,3,4,5,6,7,8,9,10]; ```
## Solution
```js // solution required ```