2.6 KiB
2.6 KiB
id | title | challengeType | videoUrl | localeTitle |
---|---|---|---|---|
587d7b8a367417b2b2512b4c | Use Destructuring Assignment with the Rest Operator to Reassign Array Elements | 1 | Назначение 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
tests:
- text: ''
testString: 'assert(arr.every((v, i) => v === i + 3) && arr.length === 8,"<code>arr</code> should be <code>[3,4,5,6,7,8,9,10]</code>");'
- 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), "<code>Array.slice()</code> should not be used.");'
Challenge Seed
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
// solution required