文章详情页
javascript - Object.assign() 深拷贝和浅拷贝的问题
浏览:123日期:2023-05-05 17:16:33
问题描述
如上图,据描述,Object.assign()为浅拷贝, 为什么改变属性a不是指向同一个引用,而b.c指向了同一个引用?
问题解答
回答1:var deepCopy = function(src) { var ret = {} for (var k in src) {ret[k] = typeof src[k] ===’object’ ? deepCopy(src[k]) : src[k] } return ret}
深拷贝一直用这个方法, Object.assgin 只能深拷贝第一层, 深层的还是浅拷贝, 记住这个就行了
回答2:let obj3 = Object.assign({},obj1,{b:Object.assign({},obj1.b)});let obj4 = JSON.parse(JSON.stringify(obj1));回答3:
浅拷贝:如果属性元素为复杂杂数据类型时,内层元素拷贝引用;slice, concat, jQury的$.extend({},obj)都是浅拷贝;点击这里了解详情
标签:
JavaScript
相关文章:
1. docker容器呢SSH为什么连不通呢?2. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””3. nignx - docker内nginx 80端口被占用4. debian - docker依赖的aufs-tools源码哪里可以找到啊?5. 前端 - ng-view不能加载进模板6. android clickablespan获取选中内容7. docker网络端口映射,没有方便点的操作方法么?8. python - from ..xxxx import xxxx到底是什么意思呢?9. javascript - iframe 为什么加载网页的时候滚动条这样显示?10. 请教各位大佬,浏览器点 提交实例为什么没有反应
排行榜
