扫码关注官方订阅号
var a={"a":"a","b":"b"}; var b=a; delete a.a; console.log(b); 为什么结果是{"b":"b"}
小伙看你根骨奇佳,潜力无限,来学PHP伐。
在 js 中,对象类型的数据是引用类型值。保存在对象变量中的是对象的引用。
引用类型值是保存在堆内存中的对象,引用类型值的变量在栈内存中保存该值的内存地址,从而访问引用类型值。引用类型值是按引用访问的。
当把 a 值赋值给 b 时,b 也只是获得了这个内存地址,即 a 和 b 实际上指向的是同一个内存中的对象。
所以当操作 a 改变了这个对象的值时,变量 b 所指向的对象也会发生变化。
js里对象和数组都是地址引用,也就是说b=a只是将b指向了a的内存空间,并不会有独立副本。
所以无论a或b,都能修改这份内存空间,效果也是相同的。
顺便纠正一下,这不是json问题,是js对象问题。
js中对象 是引用传值
改动b则影响了a
你如果需要复制一个对象的值 而不影响原来的对象 那可以用循环之类的来处理
建议题主了解下引用、堆、栈等姿势
引用、堆、栈
引用只是复制了指针而不是原对象
楼主需要看一下 堆栈的概念 如果你想不这样的话 需要对这个a对象进行深层拷贝
因为delete是删除对象属性的,所以a属性被删除了 就剩{"b":"b"}了
a 和 b 实际上指向的是同一个内存中的对象,当a发生变化时b也发生了改变
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
扫描下载App
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
在 js 中,对象类型的数据是引用类型值。保存在对象变量中的是对象的引用。
当把 a 值赋值给 b 时,b 也只是获得了这个内存地址,即 a 和 b 实际上指向的是同一个内存中的对象。
所以当操作 a 改变了这个对象的值时,变量 b 所指向的对象也会发生变化。
js里对象和数组都是地址引用,也就是说b=a只是将b指向了a的内存空间,并不会有独立副本。
所以无论a或b,都能修改这份内存空间,效果也是相同的。
顺便纠正一下,这不是json问题,是js对象问题。
js中对象 是引用传值
改动b则影响了a
你如果需要复制一个对象的值 而不影响原来的对象 那可以用循环之类的来处理
建议题主了解下
引用、堆、栈
等姿势引用只是复制了指针而不是原对象
楼主需要看一下 堆栈的概念 如果你想不这样的话 需要对这个a对象进行深层拷贝
因为delete是删除对象属性的,所以a属性被删除了 就剩{"b":"b"}了
a 和 b 实际上指向的是同一个内存中的对象,当a发生变化时b也发生了改变