コンストラクタインスタンスとプロトタイプの関係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を使用してボタンホバーフラッシュダイナミック特殊効果コードを実装する
データベースの読み取りと書き込みの分離は、トラフィック量の多い大規模システムやインターネット アプリ...
私の環境: 3 centos7.5 1804マスター 192.168.100.140ノード1 192...
序文MySQL データベースの文字列型は、CHAR、VARCHAR、BINARY、BLOB、TEXT...
目次1. データ型1. MySQL空間データとは何か2. GeoJSONとは3. 空間データ型のフォ...
略語を使用すると、CSS ファイルのサイズが小さくなり、読みやすくなります。 CSS 省略形の主なル...
MySQL 8.0.13 のインストールと設定方法を皆さんと共有したいと思います。お役に立てれば幸...
Chrome ブラウザで Web ページを開くと、ページを右クリックすると 2 つの非常によく似たオ...
開発の背景:最近、私はバッチ データを MySQL データベースにインポートする機能に取り組んでいま...
長期間稼働しているデータベースの場合、テーブルがストレージ領域を占有しすぎるという問題がよく発生しま...
この記事では、一般的な MySQL 最適化方法をいくつかまとめて簡単に紹介します。これは、フルタイム...
これはウェブサイトのユーザビリティに関する記事です。著者は自身の経験に基づいて、ウェブサイトのデザイ...
目次JS 関数呼び出し、適用、バインドメソッド1. call() メソッド1. call() メソッ...
Docker に Tomcat をインストールする場合、大きなファイルをダウンロードするときなど、場...
最近、WeChatアプレットを書いていたとき、WeChatアプレットではすべてのリクエストインターフ...
この記事では、年、月、日の3段階のリンクを実現するためのJavaScriptの具体的なコードを参考ま...