js数组深拷贝
时间: 2023-06-21 17:09:38 浏览: 120
JS实现数组深拷贝的方法分析
5星 · 资源好评率100%
在JavaScript中,数组的深拷贝可以使用多种方式实现,以下是其中的几种方法:
1. 使用JSON.parse()和JSON.stringify()
```javascript
let arr1 = [1, 2, [3, 4]];
let arr2 = JSON.parse(JSON.stringify(arr1));
```
该方法将数组先转换为JSON字符串,然后再将其解析为数组对象,从而实现深拷贝。但是,该方法有一些限制:它不能复制函数、RegExp对象等。
2. 使用递归实现深拷贝
```javascript
function deepClone(obj) {
if (obj === null || typeof obj !== 'object') {
return obj;
}
let newObj = Array.isArray(obj) ? [] : {};
for (let key in obj) {
newObj[key] = deepClone(obj[key]);
}
return newObj;
}
let arr1 = [1, 2, [3, 4]];
let arr2 = deepClone(arr1);
```
该方法通过递归实现深拷贝,可以复制所有类型的对象,但是存在一些缺点:它不能复制循环引用的对象,而且对于一些特殊的对象,比如Date、RegExp等,需要特殊处理。
3. 使用ES6的扩展运算符
```javascript
let arr1 = [1, 2, [3, 4]];
let arr2 = [...arr1];
```
该方法使用ES6的扩展运算符可以简单地实现数组的浅拷贝,但是对于多维数组或对象数组,需要使用递归或其他方法实现。
以上是几种实现数组深拷贝的方法,具体使用哪种方法取决于具体的情况。
阅读全文