登录
首页 >  文章 >  前端

如何利用 Array.prototype.fill() 配合 map() 创建一个填充了唯一对象引用的矩阵数组

时间:2026-05-04 13:12:41 173浏览 收藏

你在学习文章相关的知识吗?本文《如何利用 Array.prototype.fill() 配合 map() 创建一个填充了唯一对象引用的矩阵数组》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

fill() 无法生成独立引用矩阵,因它复制同一对象引用;正确做法是在 map 回调中每次新建对象,或用 Array.from({length:n}) 替代以避免空位问题。

如何利用 Array.prototype.fill() 配合 map() 创建一个填充了唯一对象引用的矩阵数组

直接用 fill() 填充对象再 map() 无法得到独立引用的矩阵,因为 fill() 会把**同一个对象引用**复制多次。要生成每个元素都是**全新、独立对象**的二维数组(即矩阵),必须在 map() 内部每次创建新对象。

为什么 fill(obj).map(...) 不行?

Array(3).fill({x: 0}) 创建的是一个含 3 个元素的数组,但所有元素都指向内存中**同一个对象**。后续修改任一元素(如 arr[0].x = 1),其他位置也会跟着变 —— 这不是真正的矩阵,只是同一对象的多个别名。

正确做法:在 map 回调里构造新对象

利用 Array(n) 创建稀疏数组,再用 map() 遍历时**为每一项单独 new 或字面量创建对象**,确保引用隔离:

  • 基础二维矩阵(每格是独立空对象)
    Array(3).fill().map(() => Array(4).fill().map(() => ({})))
  • 带初始值的对象矩阵(如 {row, col, id})
    Array(3).fill().map((_, i) => Array(4).fill().map((_, j) => ({ row: i, col: j, id: Symbol() })))
  • 复用构造函数或工厂函数
    const createCell = () => ({ value: null, dirty: false });
    Array(2).fill().map(() => Array(5).fill().map(createCell))

注意 fill() 的坑:不能省略 fill()

Array(3).map(...) 不会执行回调 —— 因为 Array(n) 创建的是**空位(empty slots)**,不是 undefined 元素。map() 会跳过空位。必须先用 fill()(哪怕填 undefined)把空位“激活”成可遍历元素,map() 才能生效。

替代写法:更直观的 Array.from

如果想跳过 fill() 步骤,用 Array.from 更语义化:

  • Array.from({length: 3}, () => Array.from({length: 4}, () => ({})))
  • Array.from({length: 3}, (_, i) => Array.from({length: 4}, (_, j) => ({i, j})))

它天然处理稀疏数组,无需先 fill(),逻辑更清晰。

今天关于《如何利用 Array.prototype.fill() 配合 map() 创建一个填充了唯一对象引用的矩阵数组》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>