ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript のプロトタイプ チェーン: 継承とオブジェクト ルックアップについて
プロトタイプ チェーンは、JavaScript の継承モデルの基本概念です。これにより、オブジェクトが他のオブジェクトからプロパティやメソッドを継承できるようになり、JavaScript での継承の仕組みの背後にある重要なメカニズムとなります。
JavaScript でオブジェクトを作成すると、そのオブジェクトはプロトタイプとして機能する別のオブジェクトにリンクされます。すべてのオブジェクトには、プロトタイプ オブジェクトを参照する非表示の内部プロパティ [[Prototype]] があります。
オブジェクトのプロパティまたはメソッドにアクセスすると、JavaScript はまずそのオブジェクトにプロパティが存在するかどうかを確認します。そうでない場合、JavaScript はチェーンをオブジェクトのプロトタイプまで検索し、次にそのプロトタイプのプロトタイプを検索し、Object.prototype (プロトタイプ チェーンのルート) に到達するまで検索します。プロパティまたはメソッドがチェーンのどのレベルでも見つからない場合、JavaScript は unknown を返します。
// Constructor function for Animal function Animal(name) { this.name = name; } // Adding a method to Animal's prototype Animal.prototype.speak = function() { console.log(this.name + " makes a noise."); }; // Constructor function for Dog function Dog(name) { Animal.call(this, name); // Inherit properties from Animal } // Set up the prototype chain so Dog inherits from Animal Dog.prototype = Object.create(Animal.prototype); Dog.prototype.constructor = Dog; // Reset the constructor reference // Create an instance of Dog const dog = new Dog("Buddy"); dog.speak(); // Output: "Buddy makes a noise."
この例では:
JavaScript のすべてのオブジェクトは、最終的に、プロトタイプ チェーンの最上位のプロトタイプ オブジェクトである Object.prototype を継承します。これは、配列、関数、ユーザー定義オブジェクトなどの組み込みオブジェクトのインスタンスを含むすべてのオブジェクトが、Object.prototype.
で定義されたメソッドとプロパティにアクセスできることを意味します。
const obj = {}; console.log(obj.toString()); // Output: "[object Object]" // The toString method is inherited from Object.prototype
次の例を考えてみましょう:
function Person(name) { this.name = name; } Person.prototype.sayHello = function() { console.log("Hello, " + this.name); }; const john = new Person("John"); console.log(john.sayHello()); // Output: "Hello, John" console.log(john.toString()); // Output: "[object Object]"
この場合、john のプロトタイプ チェーンは次のようになります:
// Constructor function for Animal function Animal(name) { this.name = name; } // Adding a method to Animal's prototype Animal.prototype.speak = function() { console.log(this.name + " makes a noise."); }; // Constructor function for Dog function Dog(name) { Animal.call(this, name); // Inherit properties from Animal } // Set up the prototype chain so Dog inherits from Animal Dog.prototype = Object.create(Animal.prototype); Dog.prototype.constructor = Dog; // Reset the constructor reference // Create an instance of Dog const dog = new Dog("Buddy"); dog.speak(); // Output: "Buddy makes a noise."
JavaScript のプロトタイプ チェーンにより、強力な継承機能が有効になり、オブジェクトが他のオブジェクトからプロパティやメソッドを継承できるようになります。プロトタイプ チェーンがどのように機能するかを理解することは、JavaScript をマスターし、より効率的なオブジェクト指向のコードを作成するために重要です。
こんにちは、アバイ・シン・カタヤットです!
私はフロントエンドとバックエンドの両方のテクノロジーの専門知識を持つフルスタック開発者です。私はさまざまなプログラミング言語やフレームワークを使用して、効率的でスケーラブルでユーザーフレンドリーなアプリケーションを構築しています。
ビジネス用メールアドレス kaashshorts28@gmail.com までお気軽にご連絡ください。
以上がJavaScript のプロトタイプ チェーン: 継承とオブジェクト ルックアップについての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。