ホームページ > ウェブフロントエンド > jsチュートリアル > Javascriptのプライベートメンバーとは何ですか

Javascriptのプライベートメンバーとは何ですか

醉折花枝作酒筹
リリース: 2023-01-07 11:43:42
オリジナル
2630 人が閲覧しました

プライベート メンバーはコンストラクターによって生成される必要があります。このコンストラクターには、param、secret、self という 3 つのプライベート インスタンス変数があります。これらはオブジェクトにアタッチされますが、外部からアクセスできず、オブジェクトのパブリック メソッドからもアクセスできません。これらはプライベートメンバーのみに表示されます。

Javascriptのプライベートメンバーとは何ですか

このチュートリアルの動作環境: Windows7 システム、JavaScript バージョン 1.8.5、Dell G3 コンピューター。

JavaScript は世界で最も誤解されている言語です。多くの人は、情報隠蔽機能が欠けているため、オブジェクトはプライベートなインスタンス変数やメソッドを持つことができないと考えています。しかし、これは誤解です。 JavaScript オブジェクトはプライベート変数を持つこともできます。以下で説明しましょう:

Object

JavaScript は基本的にオブジェクト (Object) に関するものです。配列はオブジェクト、関数はオブジェクトですが、オブジェクトについては説明しません。では、オブジェクトとは何でしょうか?オブジェクトは、名前と値のペアのコレクションです。名前は文字列であり、値は文字列、数値、ブール値、オブジェクト (配列や関数を含む) です。多くの場合、オブジェクトは値にすばやくアクセスするためにハッシュ テーブルとして実装されます。

値が関数の場合、それをメソッドとして扱うことができます。オブジェクトのメソッドが呼び出されると、 this 変数がそのオブジェクトに設定されます。このメソッドを使用すると、この変数を通じてインスタンス変数にアクセスできます。

オブジェクトは、オブジェクトを初期化する関数であるコンストラクターによって生成されます。コンストラクターは、静的メソッドや変数など、他の言語のクラスが提供する機能を提供します。

パブリック メンバー

オブジェクトのメンバーはすべてパブリックなパブリック メンバーです。どの関数でもこれらのメンバーにアクセス、変更、削除できます。新しいオブジェクトにメンバーを追加するには、主に 2 つの方法があります。

コンストラクター内で

#この手法は、通常、パブリック インスタンス変数を初期化するために使用されます。コンストラクターの this 変数は、オブジェクトにメンバーを追加するために使用されます。

function Container(param) {    
    this.member = param;
}
ログイン後にコピー

このようにして、新しいオブジェクトを構築すると

var myContainer = new Container('abc');
ログイン後にコピー

となり、myContainer.memberには「abc」が含まれます。

プロトタイプ内

この手法は通常、パブリック メソッドを追加するために使用されます。メンバーが取得されてオブジェクト内に見つからない場合は、オブジェクトのコンストラクターのプロトタイプ メンバーから取得されます。このプロトタイプのメカニズムは、継承を実装するために使用できます。メモリも節約できます。コンストラクターによって生成されたすべてのオブジェクトにメソッドを追加するには、コンストラクターのプロトタイプに関数を追加します。

Container.prototype.stamp = function (string) {
	return this.member + string;
}
ログイン後にコピー

このようにして、このメソッドを呼び出すことができます

myContainer.stamp('def')
ログイン後にコピー

これは 'abcdef を返します'.

プライベート メンバー

プライベート メンバーはコンストラクターによって生成される必要があります。コンストラクター内の通常の var 変数とパラメーターはプライベート メンバーになります。

function Container(param) {
	this.member = param;
    var secret = 3;
    var self = this;
    }
ログイン後にコピー

このコンストラクターには、param、secret、self という 3 つのプライベート インスタンス変数があります。これらはオブジェクトにアタッチされますが、外部からアクセスできず、オブジェクトのパブリック メソッドからもアクセスできません。これらはプライベートメンバーのみに表示されます。プライベート メソッドはコンストラクター内の関数です。

function Container(param) {

	function dec() {
		if (secret > 0) {
			secret -= 1;
			return true;
		} else {
			return false;
		}
	}

	this.member = param;
	var secret = 3;
	var self = this;
}
ログイン後にコピー

プライベート メソッド dec は、シークレット インスタンス変数をチェックします。 0 より大きい場合は、シークレットのサイズを減らし、true を返します。それ以外の場合は false を返します。これにより、オブジェクトの用途は 3 つに制限されます。

慣例により、プライベートな self パラメータを与えます。これにより、オブジェクトがプライベート メソッドから見えるようになります。これは、ECMAScript 言語仕様のバグにより、内部関数に対して正しく設定できないことが原因です。

プライベート メソッドをパブリック メソッドから呼び出すことはできません。プライベート メソッドを有効にするには、特権メソッドを導入する必要があります。

特権メンバー

特権 特権メソッドは、パブリック ドメインに表示されている間、プライベート変数およびメソッドにアクセスできます。特権メソッドを削除または置換することもできますが、変更することはできません。

特権メソッドは、これを使用してコンストラクター内で割り当てられます。

function Container(param) {

	function dec() {
		if (secret > 0) {
			secret -= 1;
			return true;
		} else {
			return false;
		}
	}

	this.member = param;
	var secret = 3;
	var self = this;

	this.service = function () {
		if (dec()) {
			return self.member;
		} else {
			return null;
		}
	};
}
ログイン後にコピー

service は特権メソッドです。最初の 3 回の呼び出しでは「abc」が返されます。それ以降はnullを返します。サービスによって呼び出されるプライベート dec メソッド、および dec はプライベート シークレット変数にアクセスします。サービスは他のオブジェクトやメソッドから参照できますが、プライベート メンバーに直接アクセスすることはできません。

クロージャー

パブリック、プライベート、特権メンバーのこのパターンが可能な理由は、JavaScript にクロージャーがあるためです。これは、外部関数が戻った後でも、内部関数は常に関数の外部の変数とパラメーターにアクセスできることを意味します。これは、この言語の非常に強力な機能です。現在の JavaScript プログラミングに関する書籍には、この機能を活用する方法が記載されていません。ほとんどは言及されていません。

プライベート メンバーと特権メンバーは、オブジェクトの構築中にのみ生成できます。公開メンバーはいつでも追加できます。

Mode

Public(Public)

function Constructor(...) {
	this.membername = value;
}
Constructor.prototype.membername = value;
ログイン後にコピー

Private(Private)

function Constructor(...) {  
	var self =  this;
	var membername =  value;  
	function  membername(...)  {...}
}
ログイン後にコピー

実際の関数ステートメント

function  membername(...)  {...}
ログイン後にコピー

は次のとおりであることに注意してください。ステートメントの省略形が続きます。どちらも同じです:

var  membername = function  membername(...)  {...};
ログイン後にコピー

Privileged

function Constructor(...) {  
	this.membername =  function (...)  {...};
}
ログイン後にコピー

[推奨学習: JavaScript 上級チュートリアル ]

以上がJavascriptのプライベートメンバーとは何ですかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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