JavaScriptで多次元配列の初期化を行う

JavaScriptで多次元配列の初期化を行う

2019-05-057 min read

目次

  1. 概要
  2. 1次元配列
  3. 2次元配列
  4. 3次元配列
  5. 参考

概要

JavaScript(ES2015)で多次元配列を任意の値で初期化する方法について。

1次元配列

例えば、

let arr = new Array(5);

と宣言した場合

console.log(arr[0]);
// undefined

となります。

ここでfillメソッドを使うことで初期化することができます。

let arr = new Array(5).fill(0);
console.log(JSON.stringify(arr));
// [0,0,0,0,0]

2次元配列

Array.from()を使って浅いコピーを行い2次元行列を生成します。

Array.from(new Array(3), () => new Array(3).fill(0));
console.log(JSON.stringify(arr));
// [[0,0,0],[0,0,0],[0,0,0]]

調べたら色々な方法が出てきますが、見た中で一番スマートな方法はこれだと思います。

ちなみに以下のように生成した場合、参照先が同じ配列となるため、 期待とは異なる配列が生成されるようです。

let arr = new Array(3).fill(new Array(3).fill(0));
console.log(JSON.stringify(arr));
// [[0,0,0],[0,0,0],[0,0,0]]
arr[0][0] = 1;
console.log(JSON.stringify(arr));
// [[1,0,0],[1,0,0],[1,0,0]]

3次元配列

2次元配列の生成を応用して3次元配列を生成してみます。 画像のRGB値を扱うときに便利かもしれません。

let arr = Array.from(new Array(3), () => {
  return Array.from(new Array(3), () => new Array(3).fill(0));
});
console.log(JSON.stringify(arr));
// [
//     [[0,0,0],[0,0,0],[0,0,0]],
//     [[0,0,0],[0,0,0],[0,0,0]],
//     [[0,0,0],[0,0,0],[0,0,0]]
// ]

参考

https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Array/fill

https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Array/from

https://qiita.com/butchi_y/items/db3078dced4592872a9c

Author
githubzennqiita
ただの備忘録です。

※外部送信に関する公表事項