作家
登录

改进版通过Json对象实现深复制的方法

作者: 来源:www.28hudong.com 2013-03-30 00:21:32 阅读 我要评论

之前看到博客的关于Json对象的深复制方法,即 复制代码 代码如下: var obj = { sayName: function() { alert(this.name); }, name:'静水渊' };var cloneObj=JSON.parse(JSON.stringify(obj));cloneObj.sayName(); 但这种方式,不能复制属性值是函数的属性,因此改进了方法,以下是具体代码: 复制代码 代码如下: var obj = { sayName: function() { alert(this.name); }, name:'静水渊' }; function clone(){ var str,newObj; str= JSON.stringify(obj, function(key, value) { return (typeof value == 'function' ? value.toString().replace(/^function(.*)/g, "jsonFunction$1") : value); }); newObj = JSON.parse(str, function (key, value) { if (/^jsonFunction(.*)/.test(value)) { var strFun = '('+value.replace(/^jsonFunction(.*)/, "function$1")+')'; value = eval(strFun); } return value; }); return newObj; } var cloneObj=clone(obj); cloneObj.sayName(); 因为还没有全面测试过,欢迎拍砖!

  推荐阅读

  js模拟点击事件实现代码

html: 复制代码 代码如下: <h3>请单击“提交”,测试提交按钮的单击事件也被触发了。</h3> <button id="btn">提交</button> <form action="#" method="get" id="form"> <input type="text" name="site" value="www>>>详细阅读


本文标题:改进版通过Json对象实现深复制的方法

地址:http://www.17bianji.com/kaifa2/JS/23002.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)