ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript でネストされたオブジェクトの親オブジェクトにアクセスするにはどうすればよいですか?

JavaScript でネストされたオブジェクトの親オブジェクトにアクセスするにはどうすればよいですか?

Susan Sarandon
リリース: 2024-10-25 03:29:29
オリジナル
408 人が閲覧しました

How can I access the parent object of a nested object in JavaScript?

JavaScript でネストされたオブジェクトの親オブジェクトを取得する

ネストされた JavaScript オブジェクトを操作する場合、その親オブジェクトにアクセスすると便利です。指定されたネストされたオブジェクト。ただし、これは JavaScript 内では直接可能ではありません。

ネストされたオブジェクト (子オブジェクト) には、親オブジェクト (親オブジェクト) への明示的な参照がありません。これは、子オブジェクトが親オブジェクトのプロパティやメソッドに直接アクセスできないことを意味します。

たとえば、次のオブジェクト階層があるとします:

<code class="js">obj: { subObj: { foo: 'hello world' } };</code>
ログイン後にコピー

サブオブジェクトへの参照の割り当て:

<code class="js">var s = obj.subObj;</code>
ログイン後にコピー

s が obj オブジェクトに直接アクセスするための組み込みメソッドはありません。

これに対処する 1 つのアプローチは、子オブジェクト内に親オブジェクトへの参照を手動で設定することです。これは関数を使用して実行できます。

<code class="js">var main = {
    name : "main object",
    child : {
        name : "child object"
    },
    init : function() {
        this.child.parent = this;
        delete this.init;
        return this;
    }
}.init();</code>
ログイン後にコピー

init 関数内で、this (メイン オブジェクト) を子オブジェクト内のparentという名前のプロパティに割り当てます。これにより、 obj:

<code class="js">s.parent.name  // Output: "main object"</code>
ログイン後にコピー

にアクセスできるようになります。このアプローチには元のオブジェクト構造の変更が含まれ、手動による初期化が必要であることに注意してください。ただし、JavaScript のネストされたオブジェクトから親オブジェクトにアクセスする方法が提供されます。

以上がJavaScript でネストされたオブジェクトの親オブジェクトにアクセスするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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