对象拷贝extend

    如果想要把某个对象拷贝(合并)给另外一个对象使用,此时可以使用$.extend()方法
      语法:
        $.extend([deep],target,object1,[objectN]);
          1.deep:如果设为true为深拷贝,默认false浅拷贝
          2.target:要拷贝的目标对象
          3.object1:待拷贝到第一个对象的对象
            4.objectN:待拷贝到第 N 个对象的对象
            5.浅拷贝是把被拷贝的对象复杂数据类型中的地址拷贝给目标对象,修改目标对象会影响被拷贝对象
            6.深拷贝,前面加true,完全克隆(拷贝的对象,而不是地址),修改目标对象不会影响被拷贝对象


        $(function(){
          var  targetObj = { } ;
          //  第一种情况:
          var  obj ={
            id : 1 ,
            name : "andy" 
          };
          $.extend( targetObj , obj ) ;   //  把 obj 中的数据 拷贝到 targetObj中
          console.log( targetObj);    //   id : 1 , name : " andy "


              //  第二种情况:
              var  targetObj = {
                id : 0
              } ;
           var  obj ={
            id : 1 ,
            name : "andy" 
             };
          $.extend( targetObj , obj ) ;   //  把 obj 中的数据 拷贝到 targetObj中
          console.log( targetObj);    //   id : 1 , name : " andy "  //  会覆盖 targetObj 里面的数据
    
                                
              //  第三种情况:
              var  targetObj = {
                id : 0
                msg : {
                    sex : ' 男 '
                } 
              } ;
           var  obj ={
            id : 1 ,
            name : "andy" 
            msg : {
               age : 18
            } 
             };
          $.extend( targetObj , obj ) ;   //  把 obj 中的数据 浅拷贝到 targetObj中
          console.log( targetObj);    //   id : 1 , name : " andy " msg{age:18} //  会覆盖 targetObj 里面的数据 ,复杂对象只会拷贝数据中的地址    
    
 
              //  第四种情况:
              var  targetObj = {
                id : 0
                msg : {
                    sex : ' 男 '
                } 
              } ;
           var  obj ={
            id : 1 ,
            name : "andy" 
            msg : {
               age : 18
            } 
             };
          $.extend( true , targetObj , obj ) ;   //  把 obj 中的数据 深拷贝到 targetObj中
          console.log( targetObj);    //   id : 1 , name : " andy " msg{age:18,sex:'男'} //  深拷贝把里面的数据完全复制一份给目标对象,如果里面有不冲突的属性,会合并到一起

        })

  

转载于:https://www.cnblogs.com/qtbb/p/11350590.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值