Как сделать копию массива на js
Ответы

Кирилл Маркеев
19 октября 2022
Можно несколькими способами сделать копию массива.
- С помощью цикла
for
:
const array = [1, 2, 3, 'hello', true, [4, 5]];
const arrayCopy = [];
for (let i = 0; i < array.length; i += 1) {
arrayCopy[i] = array[i];
}
console.log(arrayCopy); // => [1, 2, 3, 'hello', true, [4, 5]]
// убеждаемся, что это другой массив
console.log(array === arrayCopy); // => false
- С помощью метода
map()
:
const arrayCopy = array.map((element) => element);
console.log(arrayCopy); // => [1, 2, 3, 'hello', true, [4, 5]]
console.log(array === arrayCopy); // => false
- С помощью комбинации методов
JSON.parse()
иJSON.stringify()
(подходит для глубокого копирования массивов и объектов):
const arrayCopy = JSON.parse(JSON.stringify(array));
console.log(arrayCopy); // => [1, 2, 3, 'hello', true, [4, 5]]
console.log(array === arrayCopy); // => false
- С помощью метода
concat()
:
const arrayCopy = array.concat([]);
console.log(arrayCopy); // => [1, 2, 3, 'hello', true, [4, 5]]
console.log(array === arrayCopy); // => false
- С помощью метода
Array.from()
:
const arrayCopy = Array.from(array);
console.log(arrayCopy); // => [1, 2, 3, 'hello', true, [4, 5]]
console.log(array === arrayCopy); // => false
3
0
Копию массива в js можно получить используя встроенный метод slice():
const arr = [1, 2, 3]; // получаем копию массива const copyArr = arr.slice(); console.log(copyArr); // => [1, 2, 3] // убедится в том что это другой массив можно сравнив ссылки на массивы arr === copyArr // false
В качестве альтернативы можно воспользоваться возможностями spread оператора:
const arr = [1, 2, 3]; const copyArr = [...arr]; console.log(copyArr); // => [1, 2, 3] arr === copyArr // false
3
1