Array.push正确将迭代的对象推入数组,但一旦该数组由方法返回,所有对象的属性都变成了相同的。
创始人
2024-09-14 02:30:48
0

问题原因是由于 JavaScript 中的对象实际上是引用类型。当你迭代一个对象并将其推入数组时,实际上推入的是对象的引用,而不是实际的对象。这意味着当你更改一个对象的属性时,所有引用该对象的地方都会受到影响。

为了解决这个问题,你可以创建实际的对象副本并将其推入数组中,而不是将引用推入。以 ES6 为例,可以使用扩展运算符来复制对象。以下是一个示例:

const originalArray = [
  { name: 'Alice', age: 30 },
  { name: 'Bob', age: 40 },
  { name: 'Charlie', age: 50 }
];

function cloneAndPush(array) {
  const newArray = [];
  array.forEach(item => {
    newArray.push({ ...item });
  });
  newArray.push({ name: 'David', age: 60 });
  return newArray;
}

const newArray = cloneAndPush(originalArray);

console.log(newArray); // [{name: "Alice", age: 30}, {name: "Bob", age: 40}, {name: "Charlie", age: 50}, {name: "David", age: 60}]

在这个例子中,cloneAndPush() 函数复制原始数组中的每个对象,将其推入新的数组中并返回新的数组。现在,新数组中的对象以及原始数组中的对象没有任何关系,因此修改一个对象的属性不会影响另一个对象的属性。

相关内容

热门资讯

透视揭露!wepoker辅助脚... 透视揭露!wepoker辅助脚本,wepoker私人局透视-确实是真的有辅助神器(哔哩哔哩)1、下载...
透视科普!wpk透视是真的假的... 透视科普!wpk透视是真的假的,wpk软件是正规的吗-真是存在有辅助软件(哔哩哔哩)1、金币登录送、...
透视解密!wepoker辅助真... 透视解密!wepoker辅助真的假的,We poker辅助器下载-真是真的有辅助神器(哔哩哔哩)亲,...
透视推荐!hhpoker辅助软... 透视推荐!hhpoker辅助软件,hhpoker德州有挂吗-果然是有辅助神器(哔哩哔哩)1、模拟器是...
透视科普!wpk透视是真的假的... 透视科普!wpk透视是真的假的,wpk辅助器是真的吗-真是是真的有辅助攻略(哔哩哔哩)1、有没有辅助...
透视曝光!wepoker可以透... 透视曝光!wepoker可以透视码,wejoker内置辅助-本来有辅助教程(哔哩哔哩)1、该软件可以...
透视揭露!wepoker破解工... 透视揭露!wepoker破解工具,wepoker怎么设置盖牌-本来一直总是有辅助方法(哔哩哔哩)1、...
透视有挂!有哪些免费的wpk作... 透视有挂!有哪些免费的wpk作弊码,wpk辅助器是真的吗-果然一直总是有辅助脚本(哔哩哔哩)1、公共...
透视关于!德扑圈透视挂,德普之... 透视关于!德扑圈透视挂,德普之星透视辅助-好像是真的有辅助软件(哔哩哔哩)脚本下载中分为三种模型:挂...
透视解密!德普辅助器怎么用,德... 透视解密!德普辅助器怎么用,德普之星透视-好像是有辅助app(哔哩哔哩)1、完成辅助器v3.3的残局...