加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

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来实现拷贝时,使用浅拷贝时,只会将对象内一层的变量进行直接赋值,如果对象中嵌套了对象,内部的对象就会被直接赋值,形成引用赋值,修改变量就会引起其他变量的变化。为了能够拷贝多层变量,我们可以使用深拷贝,当然如果两拷贝对象中有相同的属性名时,后者的值也会覆盖前者的值。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读