js中怎么复制一个数组

前端开发   发布日期:2025年02月13日   浏览次数:174

这篇“js中怎么复制一个数组”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“js中怎么复制一个数组”文章吧。

    在js中,我们经常会用到数组复制,Array是引用类型,如果用arrA=arrB简单的把一个数组赋值,并没有创造出一个新数组,arrA和arrB其实指向的还是同一个地址,改变一个另一个也会随之改变,很明显这并不是我们想要的

    1. var arr = [1, 2, 3];
    2. var newArr = arr;
    3. arr.push(4);
    4. console.log(newArr1); // [1, 2, 3, 4]

    下面介绍数组的浅复制

    (适用于数组并不复杂,即数组中没有嵌套对象或者嵌套数组)

    方法一:concat()

    • concat()方法用于连接两个或多个数组;

    • concat() 方法不会更改现有数组,而是返回一个新数组,其中包含已连接数组的值。

    1. var arr = [1, 2, 3];
    2. var newArr = arr.concat();
    3. arr.push(4);
    4. console.log(newArr); // [1, 2, 3]

    方法二:slice()

    • slice() 方法以新的数组对象,返回数组中被选中的元素;

    • slice() 方法选择从给定的 start 参数开始的元素,并在给定的 end 参数处结束,但不包括;

    • slice() 方法不会改变原始数组;

    1. var arr = [1, 2, 3];
    2. var newArr = arr.slice();
    3. arr[0] = 10;
    4. console.log(arr);// [10, 2, 3]
    5. console.log(newArr);// [1, 2, 3]

    方法三:扩展运算符

    1. var arr = [1, 2, 3];
    2. var [ ...newArr ] = arr;
    3. arr[0] = 10;
    4. console.log(arr); // [10, 2, 3]
    5. console.log(newArr);// [1, 2, 3]

    方法四: Object.assign()

    1. var arr = [1, 2, 3];
    2. var newArr = Object.assign([], arr);
    3. arr[0] = 10;
    4. console.log(arr);// [10, 2, 3]
    5. console.log(newArr);// [1, 2, 3]

    如果数组元素是对象或者数组,上面四种方法就会只拷贝数组或者对象的引用,如果我们对其中一个数组进行修改,另一个数组也会发生变化

    比如:

    1. var arr = [ { a: 1 }, [ 1, 2 ], 3 ];
    2. let newArr = arr.concat();
    3. arr[0].a = 2;
    4. console.log(arr); // [ { a: 2 }, [ 1, 2 ], 3 ]
    5. console.log(newArr);// [ { a: 2 }, [ 1, 2 ], 3 ] 值被影响

    下面是深复制

    (可以完全拷贝一个数组,即使嵌套了对象或者数组,两者也不会互相影响)

    方法一:JSON.parse(JSON.stringify(arr))

    1. var arr = [ { a: 1 }, [ 1, 2 ], 3 ];
    2. // let newArr = JSON.parse(JSON.stringify(arr));
    3. let newArr = arr.concat();
    4. arr[0].a = 2;
    5. console.log(arr); // [ { a: 2 }, [ 1, 2 ], 3 ]
    6. console.log(newArr);// [ { a: 1 }, [ 1, 2 ], 3 ]

    但是该方法是有局限性的

    • 会忽略 undefined

    • 会忽略 symbol

    • 不能序列化函数

    • 不能解决循环引用的对象

    比如下面这个例子:

    1. let a = {
    2. age: undefined,
    3. sex: Symbol('male'),
    4. jobs: function() {},
    5. name: 'sun'
    6. }
    7. let b = JSON.parse(JSON.stringify(a))
    8. console.log(b) // {name: "sun"}

    方法二:通用方法(数组或对象)

    拷贝的时候判断属性值的类型,如果是对象,继续递归调用深拷贝函数(简易版)

    1. var deepCopy = function(obj) {
    2. // 判断是否是对象
    3. if (typeof obj !== 'object') return;
    4. // 判断obj类型,根据类型新建一个对象或者数组
    5. var newObj = obj instanceof Array ? [] : {}
    6. // 遍历对象,进行赋值
    7. for (var key in obj) {
    8. if (obj.hasOwnProperty(key)) {
    9. let val = obj[key];
    10. // 判断属性值的类型,如果是对象,递归调用deepCopy
    11. newObj[key] = typeof val === 'object' ? deepCopy(val) : val
    12. }
    13. }
    14. return newObj
    15. }

    方法三:利用lodash的深拷贝函数

    1. _.cloneDeep(value)

    其中value就是要深拷贝的值

    简单例子

    1. var objects = [{ 'a': 1 }, { 'b': 2 }];
    2. var deep = _.cloneDeep(objects);
    3. console.log(deep[0] === objects[0]);
    4. // => false

    在Vue中使用

    安装

    1. npm i --save lodash

    在main.js中引入

    1. import _ from 'lodash';
    2. Vue.prototype._ = _;

    使用

    1. let newObj = this._.cloneDeep(oldObj)

    以上就是js中怎么复制一个数组的详细内容,更多关于js中怎么复制一个数组的资料请关注九品源码其它相关文章!