ホームページ >ウェブフロントエンド >jsチュートリアル >プロトタイプとプロトタイプチェーンの違いと応用の分析

プロトタイプとプロトタイプチェーンの違いと応用の分析

PHPz
PHPzオリジナル
2024-01-10 11:47:11669ブラウズ

プロトタイプとプロトタイプチェーンの違いと応用の分析

プロトタイプとプロトタイプ チェーンおよびそのアプリケーションの違いを理解するには、具体的なコード例が必要です。

JavaScript では、プロトタイプ (Prototype) とプロトタイプ チェーン (Prototype Chain) は A 指向です。オブジェクトプログラミングにおいて非常に重要な概念です。それらの違いとその適用方法を理解することは、JavaScript のオブジェクト モデルと継承メカニズムをより深く理解するのに役立ちます。この記事では、プロトタイプとプロトタイプ チェーンの概念とその応用について、具体的なコード例を用いて説明します。

まず、プロトタイプを見てみましょう。 JavaScript では、すべてのオブジェクトにプロトタイプがあります。オブジェクトのプロトタイプは、プロパティとメソッドのセットを含むオブジェクトです。オブジェクトのプロパティまたはメソッドにアクセスするとき、オブジェクト自体にそのプロパティまたはメソッドがない場合、JavaScript はオブジェクトのプロトタイプ内で自動的にそれを探します。この検索プロセスをプロトタイプチェーン検索と呼びます。

Object.create() メソッドを通じてオブジェクトを作成し、そのプロトタイプを指定できます。例:

var person = {
  name: "张三",
  age: 20,
  sayHello: function() {
    console.log("你好,我是" + this.name + ",今年" + this.age + "岁。");
  }
};

var student = Object.create(person);
student.name = "李四";
student.grade = 5;
student.sayHello(); // 输出:你好,我是李四,今年20岁。

上記のコードでは、name と age の 2 つの属性と、sayHello メソッドを持つ person オブジェクトを作成しました。次に、Object.create() メソッドを使用して Student オブジェクトを作成し、そのプロトタイプを person として指定します。次に、属性 Grade を Student オブジェクトに追加します。最後に、student オブジェクトのsayHello() メソッドを呼び出すと、student オブジェクト自体にはsayHello() メソッドがないため、JavaScript はそのプロトタイプの person を検索し、対応するメソッドを見つけて実行します。

次に、プロトタイプ チェーンについて説明します。 JavaScript では、プロトタイプ チェーンは一連のオブジェクトで構成され、最後のオブジェクトのプロトタイプが null になるまで、各オブジェクトにプロトタイプがあります。このプロトタイプ チェーンの構造は次のとおりです。

student ---> person ---> Object ---> null

オブジェクトのプロパティまたはメソッドにアクセスすると、JavaScript は対応するプロパティまたはメソッドが見つかるまで、またはプロトタイプ チェーンの順序で検索します。オブジェクトのプロトタイプの完成です。最終的に対応するプロパティやメソッドが見つからなかった場合は、unknown が返されます。

プロトタイプ チェーンの概念を理解した後、次の例を通じてそのアプリケーションをよりよく理解できます。

function Animal(name) {
  this.name = name;
}

Animal.prototype.sayHello = function() {
  console.log("你好,我是" + this.name + "。");
};

function Dog(name, breed) {
  Animal.call(this, name);
  this.breed = breed;
}

Dog.prototype = Object.create(Animal.prototype);
Dog.prototype.constructor = Dog;
Dog.prototype.bark = function() {
  console.log("汪汪!");
};

var dog = new Dog("旺财", "拉布拉多");
dog.sayHello(); // 输出:你好,我是旺财。
dog.bark(); // 输出:汪汪!

上記のコードでは、Animal と Dog という 2 つのコンストラクターを定義し、Animal コンストラクターが使用されます。は動物オブジェクトを作成するために使用され、Dog コンストラクターは犬オブジェクトを作成するために使用されます。 Object.create(Animal.prototype) ステートメントを通じて、Dog のプロトタイプを Animal のプロトタイプとして指定します。これにより、Dog オブジェクトは、sayHello() などの Animal オブジェクトのメソッドを使用できるようになります。方法。 Animal.call(this, name) ステートメントを通じて、Animal コンストラクターを呼び出して、Dog オブジェクトの name プロパティを初期化します。次に、Dog プロトタイプに新しいメソッド bark() を定義します。最後に、dog という名前の Dog オブジェクトを作成し、その SayHello() メソッドと bark() メソッドを呼び出します。

上記のコード例を通じて、プロトタイプとプロトタイプ チェーンの概念、およびそのアプリケーションについて予備的に理解しました。プロトタイプとプロトタイプ チェーンは JavaScript の非常に重要な概念であり、高品質の JavaScript コードを作成するにはこれらを理解することが重要です。この記事があなたのお役に立てば幸いです。

以上がプロトタイプとプロトタイプチェーンの違いと応用の分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。