浅克隆
- 浅克隆的对象的引用值是拷贝对象里的引用,这两个对象里面的引用(如对象里的数组或者内嵌对象)指向的地方是一致的。
注意:object.assign() 也只是浅克隆。
深克隆
- 两个对象里面的引用是独立拷贝的,不指向同一个地方。
三种方法实现深拷贝
- 递归赋值所有层级属性
function deepClone(obj) {
let objClone = Array.isArray(obj) ? [] : {};
if (obj && typeof obj === 'object') {
for (key in obj) {
if (obj.hasOwnProperty(key)) {
//判断ojb子元素是否为对象,如果是,递归复制
if (obj[key] && typeof obj[key] === 'object') {
objClone[key] = deepClone(obj[key]);
} else {
//如果不是,简单复制
objClone[key] = obj[key];
}
}
}
}
return objClone;
}
let a = [1,2,3,4],
b = deepClone(a);
a[0] = 2;
console.log(a, b);
- 借用JSON对象的parse和stringify
function deepClone(obj){
let _obj = JSON.stringify(obj),
objClone = JSON.parse(_obj);
return objClone
}
let a=[0,1,[2,3],4],
b=deepClone(a);
a[0]=1;
a[2][0]=1;
console.log(a,b);
3.借用JQ的extend方法
$.extend( [deep ], target, object1 [, objectN ] )
deep
表示是否深拷贝,为true
为深拷贝,为false
,则为浅拷贝
target Object
类型 目标对象,其他对象的成员属性将被附加到该对象上。
object1 objectN
可选。 Object
类型 第一个以及第N个被合并的对象。
let a=[0,1,[2,3],4],
b=$.extend(true,[],a);
a[0]=1;
a[2][0]=1;
console.log(a,b);