JavaScript のディープ コピーとシャロー コピーの違いの概要

不言
リリース: 2018-10-16 12:01:47
転載
1959 人が閲覧しました

この記事では、JavaScript のディープ コピーとシャロー コピーの違いについて説明します。必要な方は参考にしていただければ幸いです。

この記事では、JavaScript のディープ コピーとシャロー コピーの違いについて説明します。

浅いコピー/浅いコピー

浅いコピーとは、基準値をコピーすることを指します。

var original = {"prop1" : "Prop1", "prop2" : "prop2"};
console.log(JSON.stringify(original));
// {"prop1" : "Prop1", "prop2" : "prop2"}

var shallowCopy = original;
console.log(JSON.stringify(shallowCopy));
// {"prop1" : "Prop1", "prop2" : "prop2"}

shallowCopy.prop1 = "ChangedProp1";

console.log(JSON.stringify(original));
// {"prop1" : "ChangedProp1", "prop2" : "prop2"}
console.log(JSON.stringify(shallowCopy));
// {"prop1" : "ChangedProp1", "prop2" : "prop2"}
ログイン後にコピー

https://smoothprogramming.com...JavaScript のディープ コピーとシャロー コピーの違いの概要

注:

  • 浅いコピーでは、元の値とコピーは同じ属性を共有します。

  • 浅いコピーはオブジェクト参照のみをコピーします。

  • 浅いコピーでは、コピーされたオブジェクトが変更されると、元のオブジェクトに影響が及びます。逆も同様です。

  • js では、配列とオブジェクトの割り当てはデフォルトで浅いコピーになります。

ディープ コピー

ディープ コピーとは、オブジェクトのプロパティを新しいオブジェクトに再帰的にコピーすることを指します。 jquery では $.extend を使用してディープコピーを実行します。

$.extend(deepCopy, target, object1, [objectN] )
ログイン後にコピー

最初のパラメータは true で渡され、これがディープ コピーであることを示します。target はターゲット オブジェクト、object1、つまり元のオブジェクトです。

var original = {"prop1" : "Prop1", "prop2" : "prop2"};
console.log(JSON.stringify(original));
// {"prop1" : "Prop1", "prop2" : "prop2"}

var deepCopy = $.extend(true, {}, original);
console.log(JSON.stringify(deepCopy));
// {"prop1" : "Prop1", "prop2" : "prop2"}

deepCopy.prop1 = "ChangedProp1";

console.log(JSON.stringify(original));
// {"prop1" : "Prop1", "prop2" : "prop2"}
console.log(JSON.stringify(deepCopy));
// {"prop1" : "ChangedProp1", "prop2" : "prop2"}
ログイン後にコピー

https://smoothprogramming.com...

JavaScript のディープ コピーとシャロー コピーの違いの概要

## 注:

  • ディープ コピーでは、コピーと元のオブジェクトは属性を共有しません

  • ディープ コピーの再帰コピー属性

  • ディープ コピーのコピーは元のオブジェクトに影響を与えず、その逆も同様です

  • js のすべてのプリミティブ データ型は、デフォルトでディープ コピーを実行します (ブール型、 null、未定義、数値、文字列など。


以上がJavaScript のディープ コピーとシャロー コピーの違いの概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:segmentfault.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート