js一行代码创建二维数组

文章目录

前言

使用js创建二维数组的方式有很多,最经典的莫过于使用for循环创建,相信大家都会此方法。下面我使用js原生API一行代码创建二维数组。

正文

Talk is cheap,show you my code:

const arr1 = Array(3).fill(0).map(x => Array(3).fill(0));

此代码应该也很好理解,初始化一个行列都为3且数值都为0的二维数组。
看完代码肯定会有人有疑问,此创建方式总感觉有些复杂,为何不用下面更简单的方式来创建:

const arr1 = Array(3).fill(Array(3).fill(0));

在控制台输出结果:
在这里插入图片描述
感觉确实也都是二维数组,那第二种方式岂不更简便?
但是事实真的是这样吗,真相只有一个,一行代码辨真假:

arr1[0][0] = 1;
arr2[0][0] = 1;

此时我们再打印出结果:
在这里插入图片描述
惊奇的发现方式二所创建的数组“牵一发而动全身”,感觉就是一个假的二维数组!
为什么会产生这种现象?问题十有八九就出在fill此API上,查看官方文档:
在这里插入图片描述
果不其然,害,果真是牵一发而动全身。

结语

想简便很好,但也要能满足需求,所以,既然API不满足功能需要那么我们只能退而求其次使用第一种方式创建二维数组。(或者,我们自己造一个可以满足需要的fill函数,然后。。。)

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值