面向对象的拷贝继承
<script>
var a = {
name : '小明'
};
var b = a; //对象的赋值 存在引用关系
b.name = '小强';
alert(a.name); //小强 因为互相影响
</script>
我们希望b的修改不会影响到a,b修改以后a.name还是小明
a是对象,a直接赋值给b会产生引用关系,对象会相互影响,但是我们知道基本类型的数据赋值不会相互影响
var a = {
name : '小明'
};
var b = {};
for(var attr in a){
b[attr] = a[attr]; //这样做类型的赋值就是基本类型的赋值了
}
b.name = '小强'; 这时我们给修改b.name
alert(a.name); //小明 我们发现a.name没有被影响到
由于这种赋值方法会经常被用到,故我们可以封装一个extend函数,以后直接调用函数就可以了
<script>
var a = {
name : '小明'
};
var b = {};
extend(b , a);
b.name = '小强';
alert(a.name); //小明
function extend(obj1,obj2) {
for(var attr in obj2){
obj1[attr] = obj2[attr];
}
}
</script>