javascript深拷贝和浅拷贝的区别
答案:2 悬赏:0
解决时间 2021-01-30 00:57
- 提问者网友:王者刀枪不入
- 2021-01-29 09:35
javascript深拷贝和浅拷贝的区别
最佳答案
- 二级知识专家网友:废途浑身病态
- 2021-01-29 09:49
所谓“深复制”,就是能够实现真正意义上的数组和对象的复制。它的实现并不难,只要递归调用”浅复制”就行了。
function deepCopy(p, c) {
var c = c || {};
for (var i in p) {
if (typeof p[i] === 'object') {
c[i] = (p[i].constructor === Array) ? [] : {};
deepCopy(p[i], c[i]);
} else {
c[i] = p[i];
}
}
return c;
}
function deepCopy(p, c) {
var c = c || {};
for (var i in p) {
if (typeof p[i] === 'object') {
c[i] = (p[i].constructor === Array) ? [] : {};
deepCopy(p[i], c[i]);
} else {
c[i] = p[i];
}
}
return c;
}
全部回答
- 1楼网友:你把微笑给了谁
- 2021-01-29 10:19
有效的对象拷贝应该是指深拷贝。
浅拷贝 : 就是两个js 对象指向同一块内存地址,所以当obj1 ,obj2指向obj3的时候,一旦其中一个改变,其他的便会改变!
深拷贝:就是重新复制一块内存,这样就不会互相影响。
有些时候我们定义一个数组,把这个数据赋值给跟多对象数组中的一个字段,当我们改变对象数组中的该字段的时候,我们会把原来的数组也改变了,这样就会引起其他数组对象中的对应的字段改变,这不是我们想要的。
这个时候我们会用到深拷贝。
深拷贝的方法:
var deepcopy = function(source)
{
var result;
(source instanceof array) ? (result = []) : (result = {});
for (var key in source) {
result[key] = (typeof source[key]==='object') ? deepcopy(source[key]) : source[key];
}
return result;
}
我要举报
如以上问答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯