javascript中的浅复制和深复制
Posted 黑客
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript中的浅复制和深复制相关的知识,希望对你有一定的参考价值。
//浅复制:实现基本类型的复制没有问题,但是复制的是引用类型的话,则修改child将会修改parent function extend(parent,child){ var child = child || {}, i; for(i in parent){ if(parent.hasOwnProperty(i)){ child[i] = parent[i]; } } return child; } //深复制:实现基本类型和引用类型的复制,即修改child的引用类型也不会修改parent的引用类型 function extendDeep(parent,child){ var i, toStr = Object.prototype.toString, aStr = "[object Array]", child = child || {}; for(i in parent){ if (parent.hasOwnProperty(i)) { if (typeof parent[i] === ‘object‘) { child[i] = (toStr.call(parent[i]) === aStr)?[]:{}; extendDeep(parent[i],child[i]); } else{ child[i] = parent[i]; } } } return child; } var parent = { aa:{a:123,b:678} } var child = extendDeep(parent); console.dir(child); child.aa.b = 10086; console.table(child); console.table(parent);
以上是关于javascript中的浅复制和深复制的主要内容,如果未能解决你的问题,请参考以下文章