javascript 2次元配列にデータを追加する

javascript 2次元配列にデータを追加する

javascriptで、pushメソッドを使用して、2次元配列にデータを追加するサンプルコードを記述してます。ここでは簡単なpushメソッドの使い方も記述してます。

環境

  • OS windows10 pro 64bit
  • Apache 2.4.43
  • ブラウザ chrome 102.0.5005.63

pushメソッド使い方

2次元配列にデータを追加するには、pushメソッドを使用します。

配列名.push(値)
// 2次元配列に追加するには、この値に1次元配列を指定します

pushメソッド使用例

let arr = ['java', 'c#'];

console.log(arr);
// 結果 ['java', 'c#']

arr.push('ruby');
console.log(arr);
// 結果 ['java', 'c#', 'ruby']

これを、2次元配列にも使用します。追加するのは、1次元配列です。

let arr = [['java', 'c#']];

arr.push(['ruby','rails']);

console.log(arr);

実行結果を見ると、データ追加されていることが確認できます。

サンプルコード

以下は、2次元配列にデータを追加してフロントに表示するサンプルコードとなります。

※cssには「uikit」を使用してます。

<!DOCTYPE html>
<html lang="ja">

<head>
  <meta charset="utf-8">
  <title>mebeeサンプル</title>
  <!-- UIkit CSS -->
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/uikit@3.5.5/dist/css/uikit.min.css" />

  <!-- UIkit JS -->
  <script src="https://cdn.jsdelivr.net/npm/uikit@3.5.5/dist/js/uikit.min.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/uikit@3.5.5/dist/js/uikit-icons.min.js"></script>
</head>
<style>
  .main {
    margin: 0 auto;
    margin-top: 80px;
    display: flex;
    flex-direction: column;
    align-items: center;
    font-size: 20px;
  }
</style>
<script>

  let arr = [[11, 12], [21, 22]];

  window.onload = function () {
    arrToDisplay(arr)
  }

  function hyouji() {
    // 2次元配列にデータを追加
    arr.push([31, 32]);
    // 出力
    arrToDisplay(arr)

  };

  function arrToDisplay(arr) {
    // 出力
    let text = [];
    for (let i = 0; i < arr.length; i++) {
      text.push('<li>' + arr[i] + '</li>');
    }
    // innerHTMLを使用して表示
    let txt = document.getElementById("txt");
    txt.innerHTML = text.join('');

  };
  
</script>

<body>
  <div class="main">
    <div class="uk-light uk-background-secondary uk-padding">

      <ul id="txt" class="uk-list uk-list-square"></ul>

      <p uk-margin>
        <button class="uk-button uk-button-danger" onclick="hyouji()">配列を追加</button>
      </p>

    </div>
  </div>
</body>

</html>

2次元配列が追加されていることが確認できます。

また、上記のjavascriptは、document.getElementByIdを省略したり、for文を1行で記述したり、関数をアロー関数で記述することが可能です。

let arr = [[11, 12], [21, 22]]

window.onload = () => {
  arrToDisplay(arr)
}

const hyouji = () =>{
  
  arr.push([31, 32])    
  arrToDisplay(arr)

};

const arrToDisplay = (arr) =>{
  
  let text = []; 

  [...Array(arr.length)].forEach((v, i) => text.push('<li>' + arr[i] + '</li>'))
      
  txt.innerHTML = text.join('');
  
};