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"].");'
```