浅拷贝:就是把一个对象的地址给了另一个对象,他们指向相同,两个对象之间有共同的属性和方法,都可以使用
举个栗子:
var obj = {
age:18,
hobby:["football","basketball"]
};
var obj2 = {};
function extend(a,b){
for(var key in a){
b[key] = a[key];
}
}
extend(obj,obj2);
深拷贝:把一个对象中的所有属性/方法,遍历找到,并且在另一个对象中开辟出相应的空间,一个一个的存储到另一个对象中
栗子:
var obj = {
age:18,
hobby:["football","basketball"],
pet:{
name:"dog",
age:"5"
}
};
var obj2 = {};
//通过函数实现,把对象a中的所有数据深拷贝到对象b中
function extend(a,b){
for(var key in a){
//先获取a对象中每个属性的值
var item = a[key];
//判断:这个属性的值是不是数组,如果是:
if(item instanceof Array){
//那么在b对象中添加一个新的数组属性
b[key] = [];
//调用这个方法,把a对象这个数组的属性值,一个一个的复制到b对象的这个数组属性中
extend(item,b[key]);
//判断:这个属性的值是不是对象,如果是:
}else if(item instanceof Object){
//那么在b对象中添加一个新的空对象
b[key] = {};
//再次调用这个函数,把a对象中的属性对象的值,遍历复制到b对象的属性对象中
extend(item,b[key]);
}else{
//如果值是普通的数组,直接复制到b对象的这个属性中
b[key] = item;
}
}
}
extend(obj,obj2);