1. 比较赋值和引用
赋值
引用(对象和函数都是引用的关系)
如下是因为a,b共用一个地址
如下b=[1,2,3,4],相当于给b新建了一个地址,a和b的地址不一样
2. 浅拷贝和深拷贝
拷贝一个对象如下
从上面可以看出来obj的a值也被改变了,为了避免这个问题(浅拷贝)
var obj={a:10};
function copy(obj){
var newObj={};
for(var arr in obj){
newObj[attr]=obj[attr];
}
return newObj;
}
var obj2=copy(obj);
obj2.a=20;
alert(obj.a);//10
浅拷贝存在的问题。从如下可以看出还是会影响前面的值。所以浅拷贝只是拷贝了一层。
var obj={a:{b:10}};
function copy(obj){
var newObj={};
for(var arr in obj){
newObj[attr]=obj[attr];
}
return newObj;
}
var obj2=copy(obj);
obj2.a.b=20;
alert(obj.a.b);//20
如下深拷贝,了解深拷贝之前了解一下递归
递归:1.函数调用函数自身,执行递的动作
2.最后一次判断一个终止条件,可以执行归的动作
function test(n){
if(n=1){
return 1;
}
return n*test(n-1);
}
alert(test(4))
回归上面的问题
var obj={a:{b:10}};
function deepCopy(obj){
if(typeof obj!='object'){
return obj;
}
var newObj={};
for(var arr in obj){
newObj[attr]=deepCopy(obj[attr]);
}
return newObj;
}
var obj2=deepCopy(obj);
obj2.a.b=20;
alert(obj.a.b);//10