ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript でオブジェクトを効率的にディープ クローン作成する方法

JavaScript でオブジェクトを効率的にディープ クローン作成する方法

Susan Sarandon
リリース: 2024-12-08 21:15:12
オリジナル
770 人が閲覧しました

How to Efficiently Deep Clone Objects in JavaScript?

JavaScript でのディープ クローン作成

JavaScript オブジェクトのディープ クローンの作成は、特にクローン化されたオブジェクトへの変更が影響を与えない環境では一般的なニーズです。オリジナル。この記事では、JavaScript でディープ クローン作成を実行する最も効率的かつエレガントな方法について説明します。

バニラ JavaScript アプローチ

フレームワークに依存しないアプローチの場合、最も簡単な方法には JSON シリアル化が含まれます。 :

const cloned = JSON.parse(JSON.stringify(objectToClone));
ログイン後にコピー

このメソッドは、独自のプロパティと値を持つ新しいオブジェクトを効果的に作成し、確実に次のように変更します。クローンはオリジナルには影響しません。ただし、すべての場合、特に循環参照やシリアル化できない値を持つ複雑なオブジェクトを処理する場合には適切ではない可能性があります。

スタックを使用した再帰的アプローチ

より堅牢な方法このメソッドは、スタックを使用した再帰的アルゴリズムを使用して、複製されたオブジェクトを追跡します。このアプローチでは、オブジェクトを再帰的に走査し、ネストされたオブジェクトと配列のクローンを作成します。

function deepClone(object) {
    const stack = [object];
    const cloned = {};

    while (stack.length) {
        const current = stack.pop();
        cloned[current.id] = current.value;

        if (Array.isArray(current.value)) {
            stack.push({ id: current.id, value: cloned[current.id].slice() });
        } else if (typeof current.value === "object" && current.value !== null) {
            const newId = Date.now();
            stack.push({ id: newId, value: current.value });
            cloned[current.id][current.key] = cloned[newId];
        }
    }

    return cloned;
}
ログイン後にコピー

クロージャと循環参照の処理

クロージャまたは循環参照を持つオブジェクトのクローンを作成するには、以下が必要です。慎重な取り扱い。クロージャの場合、クローン作成時にクロージャの状態をキャプチャする必要があります。循環参照の場合、すでに複製されたオブジェクトをスキップして無限再帰を防ぐことが重要です。

エッジ ケースの考慮事項

ディープ クローン作成は、次のようなエッジ ケースでは予期しない動作をする可能性があります。 DOM オブジェクトとゲッター/セッター関数。これらの制限を理解し、特定の種類のオブジェクトを処理するための適切なメソッドを使用することが重要です。

結論

JavaScript でのディープ クローン作成は、さまざまなアプローチを通じて実現できます。自分自身の強みと限界。 JSON シリアル化方法はシンプルですが制限があります。一方、スタックを使用した再帰的アプローチは、より優れた柔軟性と堅牢性を提供します。エッジケースを理解し、適切な手法を選択することで、開発者は元のオブジェクトの状態に影響を与えることなく維持するディープ クローンを効果的に作成できます。

以上がJavaScript でオブジェクトを効率的にディープ クローン作成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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