js对象简单、深度克隆(复制)
javascript的一切实例都是对象,只是对象之间稍有不同,分为原始类型和合成类型。原始类型对象指的是字符串(String)、数值(Number)、布尔值(Boolean),合成类型对象指的是数组(Array)、对象(Object)、函数(Function)。
既然对象分为这两类,他们之间的最大差别是复制克隆的差别。普通对象存储的是对象的实际数据,而引用对象存储的是对象的引用地址,而把对象的实际内容单独存放,因为引用对象通常比较庞大,这是数据开销和内存开销优化的手段。通常初学者很难理解这部分内容,就像对象的原型一样,也是同一个概念。对象的原型也是引用对象,把原型的方法和属性放在单独内存当中,而对象的原型链则指向这个内存地址。尽管这部分内容比较拗口复杂,那其中的原理都是一致的,目的也一致。
1、原始类型对象的克隆
1.1、字符串的克隆
- var x="1";
- var y=x;
- y="2";
- // "1"
- alert(x);
- // "2"
- alert(y);
1.2、数值的克隆
- var x=1;
- var y=x;
- y=2;
- // 1
- alert(x);
- // 2
- alert(y);
1.3、布尔值的克隆
- var x=true;
- var y=x;
- y=false;
- // true
- alert(x);
- // false
- alert(y);
2、合成类型对象的克隆
2.1、数组的克隆
如果采用普通克隆:
- var x=[1,2];
- var y=x;
- y.push(3);
- // 1,2,3
- alert(x);
- // 1,2,3
- alert(y);
由上可知,原始数组x,克隆数组y,修改了克隆数组y,但也同时修改了原始数组x,这就是引用对象的特点。那么如何才能达到完整的数组克隆呢?
- var x=[1,2];
- var y=[];
- var i=0;
- var j=x.length;
- for(;i<j;i++)
- {
- y[i]=x[i];
- }
- y.push(3);
- // 1,2
- alert(x);
- // 1,2,3
- alert(y);
这样,克隆数组y,原始数组x,两个数组互补干扰,实现了完整的数组克隆。
2.2、对象的克隆
和数组的克隆同理,对象的完整克隆如下:
- var x={1:2,3:4};
- var y={};
- var i;
- for(i in x)
- {
- y[i]=x[i];
- }
- y[5]=6;
- // Object {1: 2, 3: 4}
- console.log(x);
- // Object {1: 2, 3: 4, 5: 6}
- console.log(y);
2.3、函数的克隆
var x=function(){alert(1);};
var y=x;
y=function(){alert(2);};
// function(){alert(1);};
alert(x);
// y=function(){alert(2);};
alert(y);
函数的克隆,使用“=”符号就可以了,并且在改变克隆后的对象,不会影响克隆之前的对象,因为克隆之后的对象会单独复制一次并存储实际数据的,是真实的克隆。
3、完整的对象克隆
根据1和2,总结一下完整的对象克隆,包括克隆普通对象、引用对象。在写这个方法之前,我们必须想到的是,克隆引用对象必须采用完整克隆(深度克隆),包括对象的值也是一个对象也要进行完整克隆(深度克隆)。
完整的对象克隆又称为深度对象克隆、对象的深度克隆、对象的深度复制等等。
- function clone(obj)
- {
- var o,i,j,k;
- if(typeof(obj)!="object" || obj===null)return obj;
- if(obj instanceof(Array))
- {
- o=[];
- i=0;j=obj.length;
- for(;i<j;i++)
- {
- if(typeof(obj[i])=="object" && obj[i]!=null)
- {
- o[i]=arguments.callee(obj[i]);
- }
- else
- {
- o[i]=obj[i];
- }
- }
- }
- else
- {
- o={};
- for(i in obj)
- {
- if(typeof(obj[i])=="object" && obj[i]!=null)
- {
- o[i]=arguments.callee(obj[i]);
- }
- else
- {
- o[i]=obj[i];
- }
- }
- }
- return o;
- }
4、参考资料
js对象简单、深度克隆(复制)的更多相关文章
- js对象的深度克隆
		<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ... 
- 【JavaScript代码实现三】JS对象的深度克隆
		function clone(Obj) { var buf; if (Obj instanceof Array) { buf = []; // 创建一个空的数组 var i = Obj.length; ... 
- MyDAL - 引用类型对象 .DeepClone() 深度克隆[深度复制] 工具 使用
		索引: 目录索引 一.API 列表 .DeepClone() 用于 Model / Entity / ... ... 等引用类型对象的深度克隆 特性说明 1.不需要对对象做任何特殊处理,直接 .Dee ... 
- javascript中对象的深度克隆
		记录一个常见的面试题,javascript中对象的深度克隆,转载自:http://www.2cto.com/kf/201409/332955.html 今天就聊一下一个常见的笔试.面试题,js中对象的 ... 
- JAVA对象的深度克隆
		有时候,我们需要把对象A的所有值复制给对象B(B = A),但是这样用等号给赋值你会发现,当B中的某个对象值改变时,同时也会修改到A中相应对象的值! 也许你会说,用clone()不就行了?!你的想法只 ... 
- JavaScript实现对象的深度克隆及typeof和instanceof【简洁】【分享】
		JavaScript实现对象的深度克隆 代码实现如下: <!DOCTYPE html> <html lang="en"> <head> < ... 
- js对象/数组深度复制
		今天碰到个问题,js对象.数组深度复制:之前有见过类似的,不过没有实现函数复制,今晚想了一下,实现代码如下: function clone(obj) { var a; if(obj instanceo ... 
- JavaScript对象之深度克隆
		也不知道从什么时候开始,前端圈冒出了个新词:对象深度克隆.看起来好像很高大上的样子,实际上并不新鲜,在我们的实际项目开发中,你可能早已用到,只不过由于汉字的博大精深,有些原本很简单的事物被一些看似专业 ... 
- javascript对象的深度克隆
		在做项目的时候需要向对象里面添加新属性,又不想修改原对象.于是就写: var newObj = oldObj,但是新对象属性改变后就对象也会跟着改变,这是因为无论是新对象还是旧对象,指向的内存地址都是 ... 
随机推荐
- MySQL索引分析
			索引的出现解决数据量上升导致查询越来越慢的问题,优化数据的查询,提高查询的速度. 索引 定义: 通过各种数据结构实现的值到行位置的映射.快速定位与访问特定的数据. 作用: 提高访问速度 实现主键.唯一 ... 
- css——被自己遗忘的css属性
			[属性选择器]顾名思义,属性选择器可以根据属性是否存在或属性的值来寻找元素,因此能实现某些效果.例如当鼠标停留在一个具有title属性的元素上的时候,大多数浏览器会显示一个工具提示,可以根据这个特性来 ... 
- Ubuntu下常用的快捷键
			熟练地快捷键操作可以大大的节省我们的时间,下面贴上一些快捷键的操作: 桌面常用快捷键 Alt + F1:聚焦到桌面左侧任务导航栏,可按上下键进行导航 Alt + F2:运行命令 Alt + F4:关闭 ... 
- Redis 高可用及分片集群,说了你也不懂
			Redis 简介 Memcached: 优点:高性能读写.单一数据类型.支持客户端式分布式集群.一致性hash 多核结构.多线程读写性能高. 缺点:无持久化.节点故障可能出现缓存穿透.分布式需要客户端 ... 
- python主函数
			Python的人会很不习惯Python没有main主函数. 这里简单的介绍一下,在Python中使用main函数的方法 #hello.py def foo(): str="function& ... 
- 浅学soap--------2
			使用wsdl文件: 生成wsdl <?php require('person.class.php'); // 引入生成wsdl的类文件 require('SoapDiscovery.class. ... 
- Balanced Lineup(线段树的简单了解)
			个人心得:线段树就是将一段序列拆分为一个个单独的节点,不过每俩个节点又可以联系在一起,所以就能很好的结合,比如这一题, 每次插入的时候都将这一段区间的最大最小值更新,就能大大减少时间. 这个线段树建立 ... 
- Why getting this error “django.db.utils.OperationalError: (1050, ”Table 'someTable' already exists“)”
			0down votefavorite I am getting error like django.db.utils.OperationalError: (1050, "Table 's ... 
- 如何上Chrome谷歌商店
			将以下代码复制到本地Hosts中即可. #Google Services START64.233.162.83 0.docs.google.com64.233.162.83 0.drive.googl ... 
- 笔记:加 ly 不一定是副词
			笔记:加 ly 不一定是副词 加 ly 变副词,但有些单词以 ly 结尾,长得像副词,却是形容词. costly = cost + ly a costly item. 一件昂贵的物品. lovely ... 
