splice
, который принимает индекс того, где следует начинать удаление элементов, и количество элементов для удаления. Если второй аргумент не указан, по умолчанию удаляются элементы до конца массива. Однако метод splice
мутирует исходный массив, на котором он вызывается. Вот пример: var cities = ["Чикаго", "Дели", "Исламабад", "Лондон", "Берлин"];Как мы видели в последней задаче, метод
cities.splice (3, 1); // Возвращает «Лондон» и удаляет его из массива городов
// города теперь [«Чикаго», «Дели», «Исламабад», «Берлин»]
slice
не мутирует исходный массив, а возвращает новый, который можно сохранить в переменной. Напомним, что метод slice
принимает два аргумента - индексы начала и канца среза (конец не включен) и возвращает эти элементы в новом массиве. Использование метода slice
вместо splice
помогает избежать любых побочных эффектов, связанных с массивом.
nonMutatingSplice
, используя slice
вместо splice
. Он должен ограничивать массив предоставленных cities
длиной до 3 и возвращать новый массив только с первыми тремя элементами. Не мутируйте исходный массив, предоставленный функции.
slice
method.
testString: assert(code.match(/\.slice/g));
- text: Your code should not use the splice
method.
testString: assert(!code.match(/\.splice/g));
- text: The inputCities
array should not change.
testString: assert(JSON.stringify(inputCities) === JSON.stringify(["Chicago", "Delhi", "Islamabad", "London", "Berlin"]));
- text: nonMutatingSplice(["Chicago", "Delhi", "Islamabad", "London", "Berlin"])
should return ["Chicago", "Delhi", "Islamabad"]
.
testString: assert(JSON.stringify(nonMutatingSplice(["Chicago", "Delhi", "Islamabad", "London", "Berlin"])) === JSON.stringify(["Chicago", "Delhi", "Islamabad"]));
```