88 lines
3.7 KiB
Markdown
88 lines
3.7 KiB
Markdown
---
|
||
id: 587d78b2367417b2b2512b10
|
||
title: Видалити елементи за допомогою функції splice()
|
||
challengeType: 1
|
||
forumTopicId: 301166
|
||
dashedName: remove-items-using-splice
|
||
---
|
||
|
||
# --description--
|
||
|
||
Що ж, ми дізналися, як видалити елементи з початку і кінця масиву, використовуючи `shift()` і `pop()`, але що робити, якщо ми хочемо прибрати елемент десь зі середини? Або видалити декілька елементів одразу? Якраз тут нам на допомогу може прийти `splice()`. `splice()` дозволяє нам зробити ось що: **видалити будь-яку кількість послідовних елементів** будь-де в масиві.
|
||
|
||
`splice()` може прийняти до трьох параметрів, але зараз ми зосередимося на перших двох. Перші два параметри `splice()` — це цілі числа, які позначають індекси або позиції масиву, яким викликається `splice()`. Пам'ятайте, якщо масиви є *zero-indexed*, ми б використовували `0`, щоб зазначити перший елемент масиву. Перший параметр функції `splice()` позначає індекс в масиві, з якого починають видаляти елементи, у той час як другий параметр зазначає кількість елементів, необхідних для видалення. Наприклад:
|
||
|
||
```js
|
||
let array = ['today', 'was', 'not', 'so', 'great'];
|
||
|
||
array.splice(2, 2);
|
||
```
|
||
|
||
Ось тут видаляємо 2 елементи, починаючи з третього елемента (за другим індексом). `array` отримала б значення `['today', 'was', 'great']`.
|
||
|
||
`splice()` не лише змінює масив, на який вона викликається, але й повертає новий масив, що містить значення видалених елементів:
|
||
|
||
```js
|
||
let array = ['I', 'am', 'feeling', 'really', 'happy'];
|
||
|
||
let newArray = array.splice(3, 2);
|
||
```
|
||
|
||
`newArray` має значення `['really', 'happy']`.
|
||
|
||
# --instructions--
|
||
|
||
Ми ініціалізували масив `arr`. Використовуйте `splice()`, щоб видалити елементи з `arr`, для того щоб він містив виключно елементи, які разом складають значення `10`.
|
||
|
||
# --hints--
|
||
|
||
Не потрібно змінювати вихідний рядок `const arr = [2, 4, 5, 1, 7, 5, 2, 1];`.
|
||
|
||
```js
|
||
assert(
|
||
__helpers.removeWhiteSpace(code).match(/constarr=\[2,4,5,1,7,5,2,1\];?/)
|
||
);
|
||
```
|
||
|
||
`arr` повинен містити лише елементи, які разом складають значення до `10`.
|
||
|
||
```js
|
||
assert.strictEqual(
|
||
arr.reduce((a, b) => a + b),
|
||
10
|
||
);
|
||
```
|
||
|
||
Ваш код повинен використовувати метод `splice()` у `arr`.
|
||
|
||
```js
|
||
assert(__helpers.removeWhiteSpace(code).match(/arr\.splice\(/));
|
||
```
|
||
|
||
Функція splice може лише видаляти елементи з `arr`, а не додавати їх до `arr`.
|
||
|
||
```js
|
||
assert(
|
||
!__helpers.removeWhiteSpace(code).match(/arr\.splice\(\d+,\d+,\d+.*\)/g)
|
||
);
|
||
```
|
||
|
||
# --seed--
|
||
|
||
## --seed-contents--
|
||
|
||
```js
|
||
const arr = [2, 4, 5, 1, 7, 5, 2, 1];
|
||
// Only change code below this line
|
||
|
||
// Only change code above this line
|
||
console.log(arr);
|
||
```
|
||
|
||
# --solutions--
|
||
|
||
```js
|
||
const arr = [2, 4, 5, 1, 7, 5, 2, 1];
|
||
arr.splice(1, 4);
|
||
```
|