标签:logs 数组 浅拷贝 拷贝 var return style div 深拷贝
浅拷贝
//这样的拷贝有一个问题。那就是,如果父对象的属性等于数组或另一个对象,
//那么实际上,子对象获得的只是一个内存地址,而不是真正拷贝,因此存在父对象被篡改的可能。
function extendCopy(o) { var copy = {}; for (var i in o) { cppy[i] = o[i]; } return copy; }
深拷贝
//就是能够实现真正意义上的数组和对象的拷贝。它的实现并不难,只要递归调用"浅拷贝"就行了。
function deepCopy(o, copy) { var copy = copy || {}; for (var i in o { if (typeof o[i] === ‘object‘) { copy[i] = (o[i].constructor === Array) ? [] : {}; deepCopy(o[i], copy[i]); } else { copy[i] = o[i]; } } return copy; }
标签:logs 数组 浅拷贝 拷贝 var return style div 深拷贝
原文地址:http://www.cnblogs.com/jiayuexuan/p/7488732.html