首页 >web前端 >js教程 >将 Array.prototype.fill() 与对象一起使用时如何避免引用传递?

将 Array.prototype.fill() 与对象一起使用时如何避免引用传递?

Linda Hamilton
Linda Hamilton原创
2025-01-01 13:17:10223浏览

How to Avoid Reference Passing When Using Array.prototype.fill() with Objects?

通过引用将对象传递给 Array.prototype.fill()

使用 fill() 方法初始化固定长度的数组时,分配一个对象作为值会导致所有数组元素引用同一对象,而不是创建新实例。这可能会导致修改数组元素时出现意外行为。

示例:

var arr = new Array(2).fill({});

console.log(arr[0] === arr[1]); // true
arr[0].test = 'string';
console.log(arr[1].test); // 'string'

避免引用传递:

要创建每个元素都是不同实例的对象数组,请避免直接对对象使用 fill()。相反,请遵循以下替代方法:

映射函数:

使用占位符值(例如未定义)填充数组并使用 map() 将每个元素转换为一个新对象:

var arr = new Array(2).fill().map(u => ({}));

对象工厂函数:

使用返回新对象的函数来填充数组:

var arr = new Array(2).fill().map(Object);

通过使用这些技术,您可以确保数组中的每个元素都是单独的对象,避免意外的引用传递并保持对象隔离。

以上是将 Array.prototype.fill() 与对象一起使用时如何避免引用传递?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn