Javascript初学者关于深复制和浅复制的学习笔记

Javascript初学者关于深复制和浅复制的学习
//一、Json深复制

let a = {name: '甜瓜'};
let aJson = JSON.stringify(a);//jason数据格式转成字符串
let newA = JSON.parse(aJson);//jason数据格式转成回来
console.log(newA === a);   //false-->说明指向不同的地址。
newA.name = '香蕉';//将newA的name改成香蕉
console.log(newA.name);//--->香蕉
console.log(a.name);//--->甜瓜------------->因此:改变深复制出来的对象的属性,原对象并不会改变
//二、Object.assign方法
//(一)
let b = {name: '甜瓜'};
let b1 = Object.assign({}, b);//把b对象的属性加到一个空{}中,然后讲空{}放到b1中
console.log(b1 === b);   //false-->说明指向不同的地址。
//(二)
let c = {
    name: '甜瓜',
    friend: {
        name: '樱桃',
        money: 1500,
    }
};
let c1 = Object.assign({}, c);//把b对象的属性加到一个空{}中,然后讲空{}放到b1中
c1.friend.money = 2500;//将c1里面的money变成2500
console.log(c);//------------>里面的money变成了2500---------->说明原对象的money属性也被修改了。
console.log(c1);//------------>里面的money变成了2500
//------>是因为Object.assign方法,当对象只有一级属性的时候,是深复制---->console.log(c1)
//再有二级属性,如:c的friend。c的friend又是一个对象,这个对象的复制就变成浅复制了----->32行代码
//三、for in方法
let d = {
    name: '甜瓜',
};

function clone(obj) {
    let newObj = {};
    for (let key in obj) {
        newObj[key] = obj[key]  //当只有一级属性的时候,这样写可以。但是如果有二级属性,对象里面又有对象,应该这样写,见下面
    }
    return newObj
}

let d1 = clone(d) //
// ===有二级属性的情况甚至多级的情况==================
let e = {
    name: '甜瓜',
    friend: {//------------------->这里就是二级属性
        name: '樱桃',
        money: 1500,
    }
};

function clone1(obj) {
    let newObj = {};
    for (let key in obj) {//----->这里就需要判断二级属性
        if (typeof obj[key] === 'object') {
            newObj[key] = clone1(obj[key])//递归调用
        } else {
            newObj[key] = obj[key]
        }

    }
    return newObj
}

let e1 = clone1(e);
e1.friend.money = 9000;
console.log(e1);//----------------->money:9000
console.log(e);//--------------->money:1500  并没有改变------->说明是深复制
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值