首页 > web前端 > js教程 > 为什么 Array.fill(Array) 在 JavaScript 中通过引用创建副本,如何避免这种情况?

为什么 Array.fill(Array) 在 JavaScript 中通过引用创建副本,如何避免这种情况?

DDD
发布: 2024-11-28 15:38:12
原创
452 人浏览过

Why Does Array.fill(Array) Create Copies by Reference in JavaScript, and How Can This Be Avoided?

Array.fill(Array) 在 JavaScript 中通过引用创建副本

Array.fill() 是用特定值填充数组的有用方法。但是,当用于在数组中创建数组时,它会产生引用问题。

考虑以下示例:

let m = Array(6).fill(Array(12).fill(0));
登录后复制

此代码尝试创建一个 6x12 矩阵,其中每个元素都是 0然而,内部数组都引用同一个数组对象。

To 。说明:

m[0][0] = 1;
console.log(m[1][0]); // Outputs 1 instead of 0
登录后复制

上面的代码输出 1,而不是 0,因为对一个元素的更改会影响引用同一数组对象的所有其他元素。

要按值创建副本,一种解决方案是使用 Array.from() 代替:

let m = Array.from({length: 6}, e => Array(12).fill(0));
登录后复制

此语法为外部数组中的每个元素创建一个新数组,结果为 true按值复制行为。

以上是为什么 Array.fill(Array) 在 JavaScript 中通过引用创建副本,如何避免这种情况?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板