勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

JavaScriptで配列をコピー後に値変更した際、元の配列の値も変更される点を解消する方法

  JavaScript

JavaScriptで配列をコピー後に値変更した際、元の配列の値も変更されてしまう。「const array1 = array2」のようにコピーすると配列の中身が入るわけではなく、インスタンスを参照するアドレスが入るため書き換わってしまう模様。スプレッド構文というもので対応できるようなので以下に実装方法をメモ。

 

ソースコード

NGケース

const test_array1 = [100, 200];
const test_array2 = test_array1;

test_array2[0] = 300;

console.log(test_array1); //Array [ 300, 200 ]
console.log(test_array2); //Array [ 300, 200 ]

感覚的にはtest_array2のみ書き換わりそうだけどtest_array1も書き換わるというNGケース。

OKケース

const test_array1 = [100, 200];
const test_array2 = [...test_array1];

test_array2[0] = 300;

console.log(test_array1); //Array [ 100, 200 ]
console.log(test_array2); //Array [ 300, 200 ]

test_array2のみ正常に書き換わった点が確認できる。

 

スプレッド構文

リファレンス

https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Operators/Spread_syntax

使いどころ

今回のような配列のコピー以外では以下参考サイトが分かりやすい。

https://zenn.dev/robon/articles/4dd535ecb71d27

https://qiita.com/Nossa/items/e6f503cbb95c8e6967f8

 

所感

スプレッド構文について使いどころがイマイチ分からず、またあまり見慣れない構文のため敬遠していたが、今回のようなピンポイントな使いどころが分かったのは勉強になった。

 - JavaScript

  関連記事

jQueryでAjax通信したデータをPHPで受け取り、zip化したファイルをダウンロードさせる方法

jQueryのAjaxで何らかのデータをPHP側に送信し、PHP側で当該データを ...

NicEdit(WYSIWYGエディタ)に画像アップロード機能を追加する方法

NicEdit(ウィジウィグエディタ)に画像アップロード機能を追加したかった。本 ...

JavaScriptのマップ用ライブラリ「MapLibre GL JS」の利用方法

あるサイトをWappalyzerで調査していた際に「MapLibre GL JS ...

郵便番号を入力すると住所を自動で入力してくれる「ajaxzip3」ライブラリの利用方法

お問い合わせフォームのようなページで郵便番号及び住所欄がある場合、ユーザーが郵便 ...

JavaScriptでフォームのバリデート時に便利な「validator.js」ライブラリの利用方法

JavaScriptでフォームのバリデートを行う際、「半角英数字 正規表現」等で ...