コンストラクタインスタンスとプロトタイプの関係1. あらゆる関数にはプロトタイププロパティがあり、これはオブジェクトである 関数F(){} console.log(F.prototype) // => オブジェクト //プロトタイプオブジェクト F.prototype.sayHi = function () { console.log('こんにちは!') } 2. コンストラクターのプロトタイプ オブジェクトには、デフォルトでコンストラクター プロパティがあり、これはプロトタイプ オブジェクトが配置されている関数を指します。 console.log(F.constructor === F) // => true //これを示します 3. コンストラクタを通じて取得されたインスタンスオブジェクトには、コンストラクタのプロトタイプオブジェクトへのポインタ_proto_が含まれます。 var インスタンス = 新しい F() console.log(instance.__proto__ === F.prototype) // => true これは、現在のコンストラクタによって作成されたインスタンスオブジェクトには、 したがって、インスタンスを使用してプロトタイプオブジェクトのメンバーに直接アクセスできます。 例: instance.sayHi() // => hi! と印刷します。 知らせ
プロトタイププロパティ
つまり、すべてのオブジェクト インスタンスが共有する必要があるプロパティとメソッドをプロトタイプ オブジェクト上で直接定義できるということです。 例: 関数 Person (名前, 年齢) { this.name = 名前 this.age = 年齢 } console.log(Person.prototype) //プロトタイプを印刷します Person.prototype.type = 'human' //プロトタイプオブジェクトのプロパティにhumanをマウントします Person.prototype.sayName = function () { //関数を定義することもできます console.log(this.name) } p1 = new Person(...) とします。 p2 = new Person(...) とします。 console.log(p1.sayName === p2.sayName) // => true
これは、すべてのインスタンスの 属性またはメンバーの検索原則複数のインスタンス オブジェクトがプロトタイプ オブジェクト内のプロパティまたはメンバーを共有できることはわかっていますが、この共有メカニズムは JS ではどのように実装されるのでしょうか。 これは属性の検索原理について言及する必要がある コードがインスタンス オブジェクトのプロパティを読み取るたびに、指定された名前のプロパティまたはメンバーの検索が実行されます。 検索プロセスは次のとおりです。 1. オブジェクトインスタンス自体から検索を開始する 2. 指定された名前の属性がインスタンスオブジェクト内に見つかった場合、その属性の値が返されます。 3. 見つからない場合は、インスタンスオブジェクトに含まれるポインターが指すプロトタイプオブジェクトの検索を続行し(上記参照)、プロトタイプオブジェクト内で指定された名前の属性を探します。 4. このプロパティがプロトタイプオブジェクト内に見つかった場合、プロパティの値が返されます。 要約する以上が、プロトタイプによってマウントされたプロパティとメソッドを複数のインスタンス オブジェクトが共有する基本原理です。 この記事はこれで終わりです。皆さんのお役に立てれば幸いです。また、123WORDPRESS.COM のその他のコンテンツにも注目していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: MySQL グラフィカル管理ツール Navicat のインストール手順
>>: CSS3を使用してボタンホバーフラッシュダイナミック特殊効果コードを実装する
序文mysqlslap は、MySQL サーバーへのクライアント負荷をシミュレートし、各ステージの時...
電話Amap API を呼び出す方法は? Amap が https://lbs.amap.com/a...
本日、ローカル開発環境で突然「入力ファイルが指定されていません」というエラーが発生してしまいました。...
1. カーディナリティとは何ですか?カーディナリティとは、MySQL テーブルの列内の異なる値の数を...
前の章では、1 つのテーブルからデータを読み取る方法を学習しました。これは比較的簡単ですが、実際のア...
NERDTree は Vim 用のファイル システム ブラウザーです。このプラグインを使用すると、ユ...
UDP の理論については詳しく説明しません。UDP に関する HelloWorld プログラムを紹介...
背景CVE-2021-21972 VMware vCenter における認証されていないコマンド実行...
#docker 検索#docker プルポーター1. イメージを取得した後、中国語パッケージをダウン...
JBoss は Tomcat を Web コンテナとして使用するため、JBoss の Web コンテ...
新しいコンピューターに変更したので、すべての環境を新しいコンピューター上で設定する必要があります。ふ...
目次1. オブジェクトをマップとして扱わない1. 未定義のプロパティはプロトタイプチェーンを通じてア...
について最近、Vue を学習する過程で、基本的な知識の練習と強化を目的として、Qunar.com の...
MyISAM ストレージエンジンMyISAM は ISAM ストレージ エンジンに基づいており、それ...
他の種類のデザインとは異なり、Web デザインは時代の発展とともに常に変化しています。したがって、W...