Javascript深度复制对象
2016-06-15 17:02
316 查看
首先我们来虚构一个复制的对象,其属性包括一个对象,一个数组,一个对象方法,一个原型方法及一个原型属性。
分析该对象,我们需要对其属性类型进行差别对待。
基本数据类型,如“number,string,boolean”可直接赋值。
引用类型(对象),这里需要特别处理Array。
是否复制原对象的原型方法
由以上分析,我们拟定复制流程
创建空对象,即sub.
采用for in遍历原始对象,即sup.
遍历过程中筛选需要复制的属性,并判断sup属性类型.(筛选方法见4)
3.1 当为基本数据类型时直接复制
3.2 当为对象类型时(typeof sup[i]===’object’),进一步判断该属性是否为数组(Object.prototype.toSting.call(arg)===”[object Array]”).
3.2.1 当为一般对象类型时,将sub[i]创建为对象。回到第一步处理sup[i]与sub[i]的深度复制。
3.2.2 当为数组类型时,将sub[i]创建为数组。回到第一步处理sup[i]与sub[i]的深度复制。
我们可以通过object.hasOwnProperty[prop]来筛选原始对象的方法及静态属性,如果不使用filter,则会遍历所有属性,包括原型方法和属性。
应用
事件是检验真理的唯一标准
![](https://img-blog.csdn.net/20160615165947987)
注意红框部分,为了证明两个对象相互独立,给他来点好玩的···
看看结果如何
![](https://img-blog.csdn.net/20160615170159847)
如此完美!!!
注意
![](https://img-blog.csdn.net/20160719103228654)
采用hasOwnProperty()进行过滤将只会克隆静态属性,不能找到原型方法。由上图很容易看到,克隆结果的’proto‘的constructor是指向object的
function Child(){ this.name="Liz"; this.favorite=['sleep','delicacy','study']; this.friends={ ctt:{ name:'Ctt', age:'22' }, cyt:{ name:'Cyt', age:'22' } }; this.say=function() { console.log('Child.say'); }; } Child.prototype.age="21"; Child.prototype.sayProto=function() { console.log('Child.prototype.say'); };
分析该对象,我们需要对其属性类型进行差别对待。
基本数据类型,如“number,string,boolean”可直接赋值。
引用类型(对象),这里需要特别处理Array。
是否复制原对象的原型方法
由以上分析,我们拟定复制流程
创建空对象,即sub.
采用for in遍历原始对象,即sup.
遍历过程中筛选需要复制的属性,并判断sup属性类型.(筛选方法见4)
3.1 当为基本数据类型时直接复制
3.2 当为对象类型时(typeof sup[i]===’object’),进一步判断该属性是否为数组(Object.prototype.toSting.call(arg)===”[object Array]”).
3.2.1 当为一般对象类型时,将sub[i]创建为对象。回到第一步处理sup[i]与sub[i]的深度复制。
3.2.2 当为数组类型时,将sub[i]创建为数组。回到第一步处理sup[i]与sub[i]的深度复制。
我们可以通过object.hasOwnProperty[prop]来筛选原始对象的方法及静态属性,如果不使用filter,则会遍历所有属性,包括原型方法和属性。
function extendDeep(sup,sub){ var i, toStr=Object.prototype.toString; aStr="[object Array]"; sub=sub||{}; for(i in sup){ if (sup.hasOwnProperty(i)) { if (typeof sup[i]==='object') { sub[i]=toStr.call(sup[i])===aStr?[]:{}; extendDeep(sup[i],sub[i]); }else{ sub[i]=sup[i]; } } } return sub; }
应用
var child1=new Child(); var child2=extendDeep(child1); console.log(child1); console.log(child2);
事件是检验真理的唯一标准
注意红框部分,为了证明两个对象相互独立,给他来点好玩的···
child2.favorite.push("reading");
看看结果如何
如此完美!!!
注意
采用hasOwnProperty()进行过滤将只会克隆静态属性,不能找到原型方法。由上图很容易看到,克隆结果的’proto‘的constructor是指向object的
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- Python动态类型的学习---引用的理解
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解