js中如何复制一个数组(浅复制、深复制) 目录 下面介绍数组的浅复制 方法一:concat() 方法二:slice() 方法三:扩展运算符 方法四: Object.assign() 下面是深复制 方法一:JSON.parse(JSON.stringify(arr)) 方法二:通用方法(数组或对象) 方法三:利用lodash的深拷贝函数
目录
- 下面介绍数组的浅复制
- 方法一:concat()
- 方法二:slice()
- 方法三:扩展运算符
- 方法四: Object.assign()
- 下面是深复制
- 方法一:JSON.parse(JSON.stringify(arr))
- 方法二:通用方法(数组或对象)
- 方法三:利用lodash的深拷贝函数
- 在Vue中使用
- 安装
- 在main.js中引入
- 使用
- 总结
在js中,我们经常会用到数组复制,Array是引用类型,如果用arrA=arrB简单的把一个数组赋值,并没有创造出一个新数组,arrA和arrB其实指向的还是同一个地址,改变一个另一个也会随之改变,很明显这并不是我们想要的
下面介绍数组的浅复制
(适用于数组并不复杂,即数组中没有嵌套对象或者嵌套数组)
方法一:concat()
- concat()方法用于连接两个或多个数组;
- concat() 方法不会更改现有数组,而是返回一个新数组,其中包含已连接数组的值。
方法二:slice()
- slice() 方法以新的数组对象,返回数组中被选中的元素;
- slice() 方法选择从给定的 start 参数开始的元素,并在给定的 end 参数处结束,但不包括;
- slice() 方法不会改变原始数组;
方法三:扩展运算符
方法四: Object.assign()
如果数组元素是对象或者数组,上面四种方法就会只拷贝数组或者对象的引用,如果我们对其中一个数组进行修改,另一个数组也会发生变化
比如:
下面是深复制
(可以完全拷贝一个数组,即使嵌套了对象或者数组,两者也不会互相影响)
方法一:JSON.parse(JSON.stringify(arr))
但是该方法是有局限性的
- 会忽略 undefined
- 会忽略 symbol
- 不能序列化函数
- 不能解决循环引用的对象
比如下面这个例子:
方法二:通用方法(数组或对象)
拷贝的时候判断属性值的类型,如果是对象,继续递归调用深拷贝函数(简易版)
方法三:利用lodash的深拷贝函数
其中value就是要深拷贝的值
简单例子
在Vue中使用
安装
在main.js中引入
使用
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。