js的深拷贝,浅拷贝
2018-02-08 00:00
423 查看
对于字符串类型,浅复制是对值的复制,对于对象来说,浅复制是对对象地址的复制,并没 有开辟新的栈,也就是复制的结果是两个对象指向同一个地址,修改其中一个对象的属性,则另一个对象的属性也会改变,而深复制则是开辟新的栈,两个对象对应两个不同的地址,修改一个对象的属性,不会改变另一个对象的属性。深复制实现代码如下:
可以从两个方法进行解决。
第一种方法、通过递归解析解决
第二种方法:通过JSON解析解决
可以从两个方法进行解决。
第一种方法、通过递归解析解决
var china = { nation : '中国', birthplaces:['北京','上海','广州'], skincolr :'yellow', friends:['sk','ls'] } //深复制,要想达到深复制就需要用递归 function deepCopy(o,c){ var c = c || {} for(var i in o){ if(typeof o[i] === 'object'){ //要考虑深复制问题了 if(o[i].constructor === Array){ //这是数组 c[i] =[] }else{ //这是对象 c[i] = {} } deepCopy(o[i],c[i]) }else{ c[i] = o[i] } } return c } var result = {name:'result'} result = deepCopy(china,result) console.dir(result)
第二种方法:通过JSON解析解决
var test ={ name:{ xing:{ first:'张', second:'李' }, ming:'老头' }, age :40, friend :['隔壁老王','宋经纪','同事'] } var result = JSON.parse(JSON.stringify(test)) result.age = 30 result.name.xing.first = '往' result.friend.push('fdagldf;ghad') console.dir(test) console.dir(result)
相关文章推荐
- js对象深拷贝与浅拷贝
- eclipse中默认js编辑器非常慢,尤其在拷贝粘贴代码时的解决方法
- js对象浅拷贝和深拷贝详解
- js的命名空间 && 单体模式 && 变量深拷贝和浅拷贝 && 页面弹窗设计
- JS中有关对象的继承以及实例化、浅拷贝深拷贝的奥秘
- JS-9-拷贝
- js 中this 使用和深层拷贝
- js深浅拷贝
- js 实现拷贝页面文本数据时,给文本结尾添加文本的出处”<p>这段文本来自我的js练习</p>”。
- win7下,Ant 配合yuicompressor对js和css进行合并、压缩、拷贝处理
- js对象的深拷贝问题
- js 数组的深浅拷贝 js对象的深浅拷贝
- js实现深拷贝和浅拷贝
- js对象深拷贝的方法
- 关于JS堆栈与拷贝
- js 数组对象的深浅拷贝
- js之深浅拷贝
- js 对象浅拷贝、深拷贝
- JS深拷贝与浅拷贝