分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 技术分享

Object.assign() {...obj} JSON.Parse 等几种拷贝的区别

发布时间:2023-09-06 01:46责任编辑:顾先生关键词:暂无标签
let obj = {
age: 10
}

let obj1 = {
???grade: 1,
???name: {
???????first: ‘bob‘
???}
}

let objS = obj1
let objA = Object.assign(obj, obj1)
let objJ = JSON.parse(JSON.stringify(obj1))
let objK = { ...obj1 }

console.log(objA)
console.log(objJ)
console.log(objK)

obj1.grade = 9
obj1.name.first = ‘chris‘

console.log(objS)
console.log(objA)
console.log(objJ)
console.log(objK)
 
 
打印结果:

{ age: 10, grade: 1, name: { first: ‘bob‘ } }

{ grade: 1, name: { first: ‘bob‘ } }

{ grade: 1, name: { first: ‘bob‘ } }

{ grade: 9, name: { first: ‘chris‘ } }

{ age: 10, grade: 1, name: { first: ‘chris‘ } }

{ grade: 1, name: { first: ‘bob‘ } }

{ grade: 1, name: { first: ‘chris‘ } }

结论: 由于对象创建在堆上 栈上的变量保存其地址 所以也叫指针变量

浅拷贝 如let simpleObj = obj;

则只拷贝了 obj在栈上的指针变量给 simpleObj 也就是说simpleObj实际存储的值是 obj的对象的内存地址 指向与 obj同样的堆内存地址 所以改变 obj的值 simpleObj 的值也会改变

深拷贝 就是copy了一份对象 放在另一块堆内存地址  改变之前的对象 对这个复制的对象不会有任何影响

js里有几种深拷贝方式

Object.assign() 不算深拷贝 也不算浅拷贝 一级拷贝 如果内层还有引用类型 就是浅拷贝了

... 扩展和 assign 一样

JSON.parse(JSON.Stringify()) 深拷贝 但是缺点是不能拷贝 constructor 方法 解决办法就是递归

Object.assign() {...obj} JSON.Parse 等几种拷贝的区别

原文地址:https://www.cnblogs.com/ChrisZhou666/p/8625407.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved