jQuery中extend实现深拷贝和浅拷贝
发布时间:2020-12-14 23:51:48 所属栏目:资源 来源:网络整理
导读:在jQuery中,我们可以使用$.extend方法简单的实现对象的拷贝。 一、extend浅拷贝 var a = { name: 'aa',age: 12,friends: [{ name: 'Jack',age: 12 },{ name: 'Tom',age: 13 }],con: { height: '160cm',weight: '61kg' }};var b = { name: 'bb',age: 14,frie
|
在jQuery中,我们可以使用$.extend方法简单的实现对象的拷贝。 一、extend浅拷贝var a = {
name: 'aa',age: 12,friends: [{
name: 'Jack',age: 12
},{
name: 'Tom',age: 13
}],con: {
height: '160cm',weight: '61kg'
}
};
var b = {
name: 'bb',age: 14,friends: [{
name: 'Amy',age: 16
}],con: {
height: '154cm',weight: '56kg'
}
};
var c = $.extend(a,b);
console.log(JSON.stringify(a));
// {"name":"bb","age":14,"friends":[{"name":"Amy","age":16}],"con":{"height":"154cm","weight":"56kg"}}
console.log(JSON.stringify(b));
//?{"name":"bb","weight":"56kg"}}
console.log(JSON.stringify(c));
//?{"name":"bb","weight":"56kg"}}extend默认是浅拷贝,在此,我们发现,是把b的值拷贝到a上,并返回了a,接着看,这几者之间的关系,还是那两个变量a与b: var c = $.extend(a,b);
b.name = 'cccc';
b.con.weight= '70kg';
console.log(JSON.stringify(a));
//?{"name":"bb","weight":"70kg"}}
console.log(JSON.stringify(b));
//?{"name":"cccc","weight":"70kg"}}
console.log(JSON.stringify(c));
//?{"name":"bb","weight":"70kg"}}因此,我们可以得知浅拷贝在拷贝内层对象时,是才用引用的方式。 var c = $.extend(a,b);
a.name = 'AAA';
a.con.height = '170cm';
console.log(JSON.stringify(a));
//?{"name":"AAA","con":{"height":"170cm","weight":"56kg"}}
console.log(JSON.stringify(c));
//?{"name":"AAA","weight":"56kg"}}由此,我们发现其实c是对a的一个引用。当然,如果我们不想串改变量a中的值,我们可以采用: var c = $.extend({},a,b);
console.log(JSON.stringify(a));
//?{"name":"aa","age":12,"friends":[{"name":"Jack","age":12},{"name":"Tom","age":13}],"con":{"height":"160cm","weight":"61kg"}}
console.log(JSON.stringify(b));
//?{"name":"bb","weight":"56kg"}}这样的话,变量a中的值就不会被拷贝而被改变了。 二、extend深拷贝依旧采用浅拷贝中的两个变量a与变量b, var c = $.extend(true,b);
console.log(JSON.stringify(a));
//?{"name":"bb","age":16},"weight":"56kg"}}可以发现,得到的变量c中包含部分变量a和变量b中的值,继续对变量b操作, var c = $.extend(true,"weight":"56kg"}}
console.log(JSON.stringify(b));
//?{"name":"cccc","weight":"56kg"}}我们发现,修改拷贝前变量第二层对象中的值时,不会反应到拷贝后的变量中的值。 当然,和浅拷贝一样,为了使得变量a不变,可以使用 var c = $.extend(true,{},b);三、总结当我们使用extend来实现拷贝时,使用浅拷贝时,只会将对象内一层的变量进行直接赋值,如果对象中嵌套了对象,内部的对象就会被直接赋值,形成引用赋值,修改变量就会引起其他变量的变化。为了能够拷贝多层变量,我们可以使用深拷贝,当然如果两拷贝对象中有相同的属性名时,后者的值也会覆盖前者的值。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
