JS-05拷贝继承

目录

1 前置问题

2 拷贝继承实现

3 拷贝封装

4 浅拷贝和深拷贝

5 应用广泛


场景:想使用某个对象中的属性,但是又不能直接修改它,于是就可以创建一个该对象的拷贝

1 前置问题

   直接将一个对象source赋值给另一个对象target,此时两个是同一个对象(共享),修改任一个对象,另一个对象也会随之改变(不能实现上述问题)

var source={name:"张三",age:18};

var target=o3

  • var source={name:"张三",age:18}
  • var target={};
  • target.name=source.name
  • target.age=source.age;

这段代码可以实现需求,但是如果属性过多,则会出现代码冗余现象。

2 拷贝继承实现

 1、已经拥有了o3对象

 2、创建一个o3对象的拷贝(克隆):for...in循环

        a、取出o3对象中的每一个属性

        b、获取到对应的属性值

        c、把属性值放到o4中

3、修改克隆对象,把该对象的name属性改为"李四"

  。。。后续如果修改了o4对象中的相关属性,就不会影响到o3

代码实现:

<script>
    var o3={name:"张三",age:18};
    var o4={};
    for (var key in o3) {//key就是o3对象中的每一个属性
        var value = o3[key];
        o4[key] = value;
    }

    o4.name="李四"
    console.log(o4);    //最终的目标对象的结果

</script>

3 拷贝封装

上面的方式很明显无法重用,实际代码编写过程中,很多时候都会使用拷贝继承的方式,所以为了重用,可以编写一个函数把他们封装起来: 

<script>
函数:封装拷贝代码块
    function extend(source,target){
        for (var key in source) {
            var value = source[key];
            target[key] = value;
        }
    }

    var o3={name:"张三",age:18};

    var o4={};
    extend(o3,o4);
    o4.name="李四";

    var o5={};
    extend(o3,o5);
    o5.name="wangwu";
</script>

4 浅拷贝和深拷贝

- 浅拷贝知识拷贝一层属性,没有内部对象

-  深拷贝其实是利用递归的原理,将对象的若干层属性拷贝出来

var students=[
    {name:"",age:""},
    {name:"",age:""}
]

5 应用广泛

+ 由于拷贝继承在实际开发中使用场景非常多,所以很多库都对此有了实现
    - jquery:$.extend

+ es6中有了对象扩展运算符仿佛就是专门为了拷贝继承而生:

  var source={name:"张三",age:18}
//让target是一个新对象,同时拥有了name、age属性
  var target={ ...source }
  var target2={ ...source,age:20 } 修改属性值 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

摸爬打滚的小M

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值