ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript のプロトタイプ定義関数からプライベート メンバー変数にアクセスするにはどうすればよいですか?

JavaScript のプロトタイプ定義関数からプライベート メンバー変数にアクセスするにはどうすればよいですか?

Susan Sarandon
リリース: 2024-10-26 14:10:30
オリジナル
525 人が閲覧しました

How to Access Private Member Variables from Prototype-Defined Functions in JavaScript?

プロトタイプ定義関数からプライベート メンバー変数へのアクセス

JavaScript では、コンストラクター内で定義されたプライベート メンバー変数にプロトタイプからアクセスできません。定義されたメソッド。これは、次のコード スニペットで明らかです。

TestClass = function(){
    var privateField = "hello";
    this.nonProtoHello = function(){alert(privateField)};
};
TestClass.prototype.prototypeHello = function(){alert(privateField)};
ログイン後にコピー

nonProtoHello は privateField に正常にアクセスしますが、prototypeHello は失敗します。

Reasoning

関数 (プロトタイプを含む) -定義されたメソッドは、それらが定義されているスコープにアクセスできます。プライベート メンバー変数はコンストラクター スコープ内で定義されているため、プロトタイプで定義されたメソッドにはアクセスできません。

解決策

プロトタイプ メソッドにプライベート変数へのアクセスを提供するには:

  • このオブジェクトのゲッターとセッターを定義します。
  • プロトタイプ メソッドは、これらのゲッターとセッターにアクセスしてプライベート変数と対話できます。

例:

function Person(name, secret) {
    // public
    this.name = name;

    // private
    var secret = secret;

    // public methods have access to private members
    this.setSecret = function(s) {
        secret = s;
    }

    this.getSecret = function() {
        return secret;
    }
}

// Must use getters/setters 
Person.prototype.spillSecret = function() { alert(this.getSecret()); };
ログイン後にコピー

このアプローチにより、プロトタイプ定義のメソッドは、カプセル化を維持しながら、ゲッターおよびセッターを介してプライベート メンバー変数と対話できるようになります。

以上がJavaScript のプロトタイプ定義関数からプライベート メンバー変数にアクセスするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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