使用JSON序列化深拷贝

生成的新对象和之前的对象并不是同一个对象:

相当于是进行了一次深拷贝;

const obj = {

name: 'why',

age: 18,

friend: {

name: 'kobe'

}

}

const objString = JSON.stringify(obj)

const info = JSON.parse(objString)

console.log(info);

//{ name: 'why', age: 18, friend: { name: 'kobe' } }

console.log(info === obj)//false

info.friend.name = "james"

console.log(obj.friend.name)//kobe

注意:这种方法它对函数是无能为力的

创建出来的info中是没有foo函数的,这是因为stringify并不会对函数进行处理;

举例:

const obj = {

name: 'why',

age: 18,

friend: {

name: 'kobe'

},

eating() {

console.log("eating~")

}

}

const objString = JSON.stringify(obj)

const info = JSON.parse(objString)

console.log(info);

//{ name: 'why', age: 18, friend: { name: 'kobe' } }

console.log(info === obj)//false

info.friend.name = "james"

console.log(obj.friend.name)//kobe

这里在obj对象中添加了方法,但是转换后的info对象中没有函数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值