【JavaScript】对象拷贝(之)深拷贝与浅拷贝

在业务代码中,经常需要对象的传递,这个时候我们需要个格外的注意!
到底是需要深拷贝的对象,还是需要浅拷贝的对象,否则在这里可能就会留下bug的隐患!

const a = {x: 1, y: {z: 2}}
// 浅拷贝
const b = a
// 第一级属性深拷贝,以后级别属性浅拷贝
const c = Object.assign({}, a)
const d = {...a}
// 深拷贝
const e = JSON.parse(JSON.stringify(a))

a.x = 5
a.y.z = 6

console.log(a) // {x: 5, y: {z: 6}}
console.log(b) // {x: 5, y: {z: 6}}
console.log(c) // {x: 1, y: {z: 6}}
console.log(d) // {x: 1, y: {z: 6}}
console.log(e) // {x: 1, y: {z: 2}}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值