zoukankan      html  css  js  c++  java
  • JS 克隆Object.prototype.Clone

    我们知道,在js中,当object作为参数传递到函数中进行处理后,实际上是修改了传入的对象本身(或者说是对象的引用),但很多时候我们并不希望函数去修改我们的这些对象参数,这就需要使用到对象的克隆,我们应该对该对象做一个克隆,然后操作这个克隆的对象,这样就不会影响我们的原对象了。 
        不过在js中并没有对象克隆功能,因此需要我们自己实现,实现方法也不复杂其实,基本上是做一些属性复制,我在网上找了一些,但有些实现并不好,如对于array对象克隆后就成json对象了,并没有保留原来的数组方式。不过最后还是找到了一个很好的克隆函数,完美实现了js对象的克隆功能,不论是Array对象或者是普通的Object,都可以很好的进行克隆,这个函数使用constructor(函数构造器)进行复制。

    Object.prototype.Clone = function(){  
        var objClone;  
        if (this.constructor == Object){  
            objClone = new this.constructor();   
        }else{  
            objClone = new this.constructor(this.valueOf());   
        }  
        for(var key in this){  
            if ( objClone[key] != this[key] ){   
                if ( typeof(this[key]) == 'object' ){   
                    objClone[key] = this[key].Clone();  
                }else{  
                    objClone[key] = this[key];  
                }  
            }  
        }  
        objClone.toString = this.toString;  
        objClone.valueOf = this.valueOf;  
        return objClone;   
    }   
    
    
    //克隆函数
    function clone(myObj){  
      if(typeof(myObj) != 'object') return myObj;  
      if(myObj == null) return myObj;  
        
      var myNewObj = new Object();  
        
      for(var i in myObj)  
        myNewObj[i] = clone(myObj[i]);  
        
      return myNewObj;  
    }  

      

  • 相关阅读:
    linux服务 ssh
    详细教你两台电脑之间传文件
    openstack之keystone
    Token
    mybatis返回刚刚插入数据的自增长的id值
    事务配置在applicationContext.xml文件中不起作用,控制不了异常回滚
    SSM框架整合
    ssm框架的小总结
    spring_mvc入门项目的小总结
    tcp和udp的网络编程(发送消息及回复)
  • 原文地址:https://www.cnblogs.com/yeyublog/p/7407481.html
Copyright © 2011-2022 走看看