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