2021-07-19 深浅拷贝的区别以及实现深拷贝的几种方法,Object.assign()是什么拷贝,自定义递归深拷贝函数的封装

本文探讨了JavaScript中深浅拷贝的区别,解释了深拷贝是如何创建独立的内存副本,而浅拷贝只是复制引用。还详细解析了`Object.assign()`的拷贝特性,指出其仅在一级属性时进行深拷贝,二级及以后属性则是浅拷贝。此外,文章介绍了实现深拷贝的多种方法,包括`JSON.parse(JSON.stringify(obj))`、jQuery的`extend()`方法,以及两种不同的递归实现方式,并提到了这些方法的优缺点和适用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.浅拷贝:拷贝的是指针
例子
var obj1 = {
    age: 18 };
var obj2 = obj1;//浅拷贝
obj2.age = 20;
console.log(obj1.age,obj2.age);//输出20 20

可以看到obj2的属性值改变后,obj1的属性值也改变,因为它们指向同一片内存空间

2.深拷贝:拷贝的是内存空间
例子
var obj1 = {
   age: 18};
var obj2 = JSON.parse(JSON.stringify(obj1));//深拷贝
obj2.age = 20;
console.log(obj1.age, obj2.age); //输出18 20

与浅拷贝不同的是,深拷贝对象与原对象的内存空间是相互独立的,彼此互不干扰

3.Object.assign是什么拷贝?
3.1.Object.assign的用法

*var returnTarget=object.assign(target,source);
前面可以不用写,仅仅保留Object.assign(target, source);输出结果都是一样的,都是两个对象合并的结果

const target = {
    a: 1, b: 2 };
const source = {
    b: 4, c: 5 };
const returnedTarget = Object.assign(target, source);
console.log(target);// expected output: Object { a: 1, b: 4, c: 5 }
console.log(returnedTarget);// expected output: Object { a: 1, b: 4, c: 5 }

target为空时叫做深拷贝,target有属性方法时叫做合并对象,本质都是把source的属性和方法复制一份给它

3.2.只有一级属性为深拷贝,二级属性后就是浅拷贝
var obj = {
   
    name: "zhangsan",
    hobbies: {
   
        am: "sleep",
        
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端OnTheRun

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值