序文:
正確に言うと、これらのプロパティとメソッドは、オブジェクト インスタンス自体ではなく、 プロトタイプとプロトタイプ チェーンは、次の 4 つの文で明らかになります。
コンストラクター、プロトタイプ、インスタンスの関係: 各 1. プロトタイプ(明示的なプロトタイプ)すべての関数には // コンストラクタ(クラス) 関数 Person(名前){ this.name = 名前 } // 新しいインスタンス(オブジェクト) var person = new Person('南玖') console.log(person) //Person { name: '南玖' } console.log(Person.prototype) //コンストラクタ関数のプロトタイプ(クラス)----->object Person.prototype.age = 18 //コンストラクタ関数のプロトタイプ console.log(person.age) // 18 上記では、オブジェクトを指すこの関数 上の図はコンストラクターとインスタンス プロトタイプの関係を示しており、コンストラクターのプロトタイプ プロパティがオブジェクトを指していることがわかります。 インスタンスとそのプロトタイプの関係は何ですか?ここで 2. __proto__ (暗黙のプロトタイプ)上記の4つの文から、これはすべての 次に、インスタンスとインスタンスプロトタイプの関係を証明します。 console.log(person.__proto__) //インスタンス (オブジェクト) プロトタイプ ---> オブジェクト console.log(person.__proto__ === Person.prototype) //インスタンスのプロトタイプはコンストラクター関数のプロトタイプと同じです 上の図から、インスタンス オブジェクトとコンストラクターの両方がプロトタイプを指すことができることがわかりますが、プロトタイプはコンストラクターまたはインスタンスを指すことができるのでしょうか? 3. コンストラクターコンストラクターは複数のインスタンス オブジェクトを作成できるため、プロトタイプにはインスタンスを指す属性はありません。 前の4つの文から、「ブラウザによってプロトタイプ用にデフォルトで割り当てられたヒープメモリには したがって、次の点を証明できます。 console.log(Person.prototype.constructor) // インスタンスの明示的なプロトタイプのコンストラクタ ƒ Person(name){this.name = name} console.log(person.__proto__.constructor) //インスタンスの暗黙的なプロトタイプコンストラクター ƒ Person(name){this.name = name} console.log(person.__proto__.constructor === Person.prototype.constructor) //true インスタンスプロトタイプのコンストラクタは、クラスのコンストラクタと同じです。console.log(Person === Person.prototype.constructor) //true インスタンス オブジェクトの 関数 Foo() {} // この関数は Function のインスタンス オブジェクトです // 関数はシンタックス シュガーです // 実際には内部で new Function() を呼び出します したがって、 4. 新しい原則簡単に言えば、次の 4 つのステップに分けられます。
関数myNew() { // 1. 新しい空のオブジェクトを作成する let obj = {} // 2. コンストラクタを取得する let con = arguments.__proto__.constructor // 3. リンクプロトタイプ obj.__proto__ = con.prototype // 4. これをバインドしてコンストラクタを実行します。let res = con.apply(obj, arguments) // 5. 新しいオブジェクトを返す return typeof res === 'object' ? res : obj } 5. プロトタイプチェーンプロトタイプについて話した後、プロトタイプ チェーンとは何かを見てみましょう。まずは写真を見てみましょう: この図では、 5.1 プロトタイプチェーンの役割プロトタイプ チェーンは、
5.2 コンストラクタの __proto__ とは何ですか?上記のプロトタイプチェーンの説明から、コンストラクター関数の 関数 Person(){} コンソールログ(Person.__proto__) console.log(関数プロトタイプ) console.log(Person.__proto__===Function.prototype) // true 「これは、すべての関数が Function のインスタンスであることも示しています」 このように理解すると、 Function.__proto__ === Function.prototype // true まさにこれが印刷される内容です。
6. まとめ
以下もご興味があるかもしれません:
|
>>: クラウドデータ移行サービスの観点から見たMySQLの大規模テーブル抽出モードの原理分析
Ubuntu 18.04 を使用する Python 開発者向けの参考資料です。 1. Ubuntu ...
目次TypeScript環境の構築ステップ1: Taobaoミラーをダウンロードするステップ2: T...
最近、監視機器の作業をしていたとき、ポートがダウンしているというアラームが常に出ていました。データを...
概要: MYSQLの問題解決記録:どのようなインストール方法 (rpm、gz、gz.xz) を使用す...
1つ。序文<br />この種の質問は、どの専門掲示板でも見かけます。Google で検索...
CSS3 は反転可能なホバー効果を実装します。具体的なコードは次のとおりです。 1.css /*基本...
目次1. 各() 2. arr.filter() 3. arr.every() 4. arr.map...
序文この記事では主に、SQL ステートメントの最適化の一般的な手順について説明します。これは、参考と...
障害の説明percona5.6、mysqldump フルバックアップ、バックアップデータのインポート...
目次2. 試した方法2.1 キープアライブ2.2 ネストされたルートを持つ CSS 3. 機能説明4...
FFMPEG 3.4.1 バージョンパラメータの詳細使用方法: ffmpeg [オプション] [[入...
目次1. 手順2. 修飾語3. .sync 修飾子4. まとめ1. 手順指示とは命令です。文字通りの...
目次グローバルオブジェクトグローバルオブジェクトとグローバル変数プロセスコンソール一般的なツールユー...
目次1. 浅いコピーとはどういう意味ですか? 2. ディープコピーとはどういう意味ですか? 3. デ...
目次動画最優秀選手ムヴヴムVueのソーススパ mpa要素を作成するクラス要約する動画 Model(模...