zoukankan      html  css  js  c++  java
  • 深拷贝 浅拷贝 理解与深挖

    首先深复制和浅复制只针对像 Object, Array 这样的复杂对象的。简单来说,浅复制只复制一层对象的属性,而深复制则递归复制了所有层级。

    对于字符串类型,浅复制是对值的复制,对于对象来说,浅复制是对对象地址的复制,并没 有开辟新的栈,也就是复制的结果是两个对象指向同一个地址,修改其中一个对象的属性,则另一个对象的属性也会改变,而深复制则是开辟新的栈,两个对象对应两个不同的地址,修改一个对象的属性,不会改变另一个对象的属性

    深拷贝的方法

    方法一、deepCopy
        var china = {
              nation : '中国',
              birthplaces:['北京','上海','广州'],
              skincolr :'yellow',
              friends:['sk','ls']
          }
          //深复制,要想达到深复制就需要用递归
          function deepCopy(o,c){
            var c = c || {}
            for(var i in o){
            if(typeof o[i] === 'object'){
                              //要考虑深复制问题了
                          if(o[i].constructor === Array){
                            //这是数组
                            c[i] =[]
                        }else{
                            //这是对象
                            c[i] = {}
                        }
                        deepCopy(o[i],c[i])
                        }else{
                             c[i] = o[i]
                        }
                 }
                 return c
          }
          var result = {name:'result'}
          result = deepCopy(china,result)
          console.dir(result)

    方法二   通过JSON对象的parse和stringify

        var test ={
              name:{
               xing:{ 
                   first:'张',
                   second:'李'
              },
              ming:'老头'
          },
          age :40,
          friend :['隔壁老王','宋经纪','同事']
         }
          var result = JSON.parse(JSON.stringify(test))
          result.age = 30
          result.name.xing.first = '往'
          result.friend.push('fdagldf;ghad')
          console.dir(test)

            

          console.dir(result)

            

    方法三  借助JQ的extend方法

    $.extend( [deep ], target, object1 [, objectN ] )

    deep表示是否深拷贝,为true为深拷贝,为false,则为浅拷贝

    target Object类型 目标对象,其他对象的成员属性将被附加到该对象上。

    object1  objectN可选。 Object类型 第一个以及第N个被合并的对象。 

    let a=[0,1,[2,3],4],
        b=$.extend(true,[],a);
    a[0]=1;
    a[2][0]=1;
    console.log(a,b);
  • 相关阅读:
    hmac
    struct模块-黏包的解决方法
    PHPCMS快速建站系列
    Notepad++搜索中的正则应用
    用var 变量=函数名 方式调用函数时如何传值的问题
    ThInkPHP中的常量
    css cursor 的可选值(鼠标的各种样式)
    JS实现用键盘控制DIV上下左右+放大缩小与变色
    PHP定义数组常量
    FormData实现文件上传实例
  • 原文地址:https://www.cnblogs.com/benbonben/p/14862170.html
Copyright © 2011-2022 走看看