var a = { name: 1 };
var arr = [a];
console.log(arr); //[{name:2}] flag1处
console.log(arr[0]); //{name:1}
a.name = 2;
console.log(arr); //[{name:2}]
console.log(arr[0]); //{name:2}
浏览器的打印结果为

我想这个问题,越想越没头绪,后面答案是

当我们点击展开时,浏览器才会去内存中取值,而这是 flag1的name早就变成了 2
在node环境下验证一下

JavaScript对象引用与浏览器、Node环境行为差异
本文探讨了JavaScript中对象赋值给数组后,修改原对象属性如何影响数组元素的问题。在浏览器环境中,当展开数组时,浏览器会实时获取对象的最新值。而在Node环境下,结果同样如此,显示了JavaScript的引用类型特性。
1万+

被折叠的 条评论
为什么被折叠?



