JS完美实现对象克隆
2011-04-26 10:47
190 查看
我们知道,在js中,当object作为参数传递到函数中进行处理后,实际上是修改了传入的对象本身(或者说是对象的引用),但很多时候我们并不希望函数去修改我们的这些对象参数,这就需要使用到对象的克隆,我们应该对该对象做一个克隆,然后操作这个克隆的对象,这样就不会影响我们的原对象了。
不过在js中并没有对象克隆功能,因此需要我们自己实现,实现方法也不复杂其实,基本上是做一些属性复制,我在网上找了一些,但有些实现并不好,如对于array对象克隆后就成json对象了,并没有保留原来的数组方式。不过最后还是找到了一个很好的克隆函数,完美实现了js对象的克隆功能,不论是Array对象或者是普通的Object,都可以很好的进行克隆,这个函数使用constructor(函数构造器)进行复制。
具体代码如下:
不过在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; }
相关文章推荐
- 用JS实现发邮件的功能 完美解决
- js实现完美身份证号有效性验证
- 设置为首页,加入收藏 | JS完美实现代码收藏
- js实现的仿新浪微博完美的时间组件升级版
- js实现的仿新浪微博完美的时间组件升级版
- 原生js倒计时完美实现
- HTML+CSS+JS实现完美兼容各大浏览器的TABLE固定列
- 【飞秋】JS 实现完美include
- js实现完美兼容各大浏览器的人民币大小写相互转换
- js实现完美身份证号有效性验…
- 纯JS转换Select为Combox,完美实现原select所有功能
- 完美实现js焦点轮播效果(二)(图片可滚动)
- JS实现图片无缝滚动的完美解决 无间隙滚动
- 完美实现八种js焦点轮播图(下篇)
- JS实现完美include加载功能代码
- js实现input输入框只能输入数字的功能(完美测试通过)
- js实现的非跨域的iframe高度自适应(完美兼容IE,FF,Opera)
- 比较完美的js的QueryString实现
- 【酷】JS+CSS实现滑动门与导航条的完美结合
- js实现完美身份证号有效性验证