随笔 - 149  文章 - 8  评论 - 248  阅读 - 21万

JavaScript中实现深浅拷贝

<script language="javascript" type="text/javascript">
    /*
    JavaScript中实现深浅拷贝
      Javascript中的对象赋值与C#中是一样的,都为引用传递,就是说,在把一个对象赋值给一个变量时,那么这个变量所指向的仍旧是原来对象的地址。
      如果我们想要一个和原来一样的新对象,那怎么来做呢?
      在实际编程过程中,我们常常要遇到这种情况:有一个对象A,在某一时刻A中已经包含了一些有效值,此时可能会需要一个和A完全相同新对象B,
      并且此后对B任何改动都不会影响到A中的值,也就是说,A与B是两个独立的对象,但B的初始值是由A对象确定的。
      在javasript语言中,用简单的赋值语句是不能满足这种需求的。要满足这种需求虽然有很多途径,但实现clone()方法是其中最简单,
      也是最高效的手段,当然了javascript语言中并没有此方法。
   下面开两个克隆方法:一个为浅复制,一个为深复制。
   浅复制:只复制对象的基本类型,对象类型,仍属于原来的引用。
   深复制:不仅复制对象的基本类型,同时也复制原对象中的对象,就是说完全是新对象产生的。
    */
        function Object.prototype.clone()   //浅拷贝
        {
            var newObj=new Object();
            for(elements in this)
            {
                newObj[elements]=this[elements];
            }
            return newObj;
        }
        function Object.prototype.cloneAll()  //深拷贝
        {
            function clonePrototype(){}
         clonePrototype.prototype = this;
         var obj = new clonePrototype();
         for(var ele in obj){
          if(typeof(obj[ele])=="object") obj[ele] = obj[ele].cloneAll();
         }
         return obj;
        }
        var obj1= new Object();
     obj1.Team= "First";
     obj1.Powers = new Array("Iori","Kyo");
     obj1.msg= function(){alert()};
     obj1.winner = new Object();
     obj1.winner.name= obj1.Powers[0];
     obj1.winner.age= 23;
     obj1.winner.from= "Japan"

     var obj1_clone= obj1.cloneAll();
     obj1_clone.Team = "Second";
     obj1_clone.Powers= new Array("Jimmy","Anndy");
     obj1_clone.winner.name= obj1_clone.Powers[1];
     obj1_clone.winner.age= 22;
     obj1_clone.winner.from= "USA";

     msg  = "2003界拳皇单打独斗杯,拳皇挑战赛:  \n\n   A组 对战形式:\n\n"
     msg += obj1.Team+" 组 ,人员名单:"+obj1.Powers+"\n";
     msg += "第一轮过后,胜利者为:"+obj1.winner.name +" ,参赛者年龄:"+obj1.winner.age+" ,来自岛国: "+obj1.winner.from+"\n";
     msg += "\n\n   B组 对战形式:\n\n"
     msg += obj1_clone.Team+" 组 ,人员名单:"+obj1_clone.Powers+"\n";
     msg += "第一轮过后,胜利者为:"+obj1_clone.winner.name +" ,参赛者年龄:"+obj1_clone.winner.age+" ,来自国际警察部队: "+obj1_clone.winner.from+"\n";
     alert(msg);        
    </script>

posted on   几度夕阳红了  阅读(512)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述
< 2009年1月 >
28 29 30 31 1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 31
1 2 3 4 5 6 7

点击右上角即可分享
微信分享提示