ホームページ ウェブフロントエンド jsチュートリアル JavaScript継承の仕組みを詳しく解説 例_JavaScriptスキル

JavaScript継承の仕組みを詳しく解説 例_JavaScriptスキル

May 16, 2016 pm 04:31 PM
javascript 機構 継承する

この記事の例では、JavaScript の継承メカニズムについて説明します。皆さんの参考に共有してください。具体的な分析は次のとおりです。

JavaScript 言語の継承メカニズムは一般に理解しにくいですが、「サブクラス」と「親クラス」という概念がなく、すべてが「クラス」と「インスタンス」に依存しています。継承を実装するための非常に独特な「プロトタイプ チェーン」モデル。

私はこの部分を勉強するのに多くの時間を費やし、たくさんのメモを取りました。しかし、それらはすべて強制された記憶であり、根本的に理解することはできません。

1. クラスの作成方法

次のような person というクラスがあるとします。

コードをコピー コードは次のとおりです:
var person = function(name, age) {
This.name = 名前;
This.age = 年齢;
}
Person.prototype.getName = function() {
this.name を返します;
}

上記のように、「人」は地球上のすべての人々を表し、誰もが名前と年齢という 2 つの基本的な属性を持っています。次に、学生クラスを実装する必要があります。そして、学生もまた人であり、学生にも次のような属性があることがわかります。名前と年齢として;問題は、この関係をどのように確立するかです。
まず、純粋なオブジェクト指向言語 (Actionscrpt3 など) がどのように機能するかを見てみましょう
コードをコピーします コードは次のとおりです。
class Students extend Person {} //非常に単純な 1 行です。コード; より正確に言うと、単語です --extend

2. jsに切り替えて行う方法

js の継承メカニズムの実装を説明する前に、まず js のプロトタイプ チェーンを理解しましょう。

コードをコピーします コードは次のとおりです。
var person = new Person('Poized-flw', 21);
person.getName(); // "ポイズド flw"

上記の getName() メソッドについては、どのように実行されるのでしょうか?まず、Person 関数で getName() メソッドを探しますが、存在しないことがわかります。次に、Person.prototype に移動して検索し、存在することを確認します。それからそれを呼び出します。そうでなかったらどうしますか?メソッドが見つかるか、プロトタイプ チェーンの先頭に到達するまで、同じ方法でプロトタイプに沿って検索を続けます。

たとえば、犬オブジェクトのプロトタイプを表す DOG というコンストラクターが追加されました。

コードをコピー コードは次のとおりです:
Function DOG(name){
this.name = 名前;
}

このコンストラクターで new を使用すると、犬オブジェクトのインスタンスが生成されます。
コードをコピー コードは次のとおりです:
var DogA = new DOG('Big Hair');
alert(dogA.name); // ダ・マオ

コンストラクター内の this キーワードに注意してください。これは、新しく作成されたインスタンス オブジェクトを表します。

3. 新しいオペレーターのデメリット

コンストラクターを使用してインスタンス オブジェクトを生成することには、プロパティとメソッドを共有できないという欠点があります。
たとえば、DOG オブジェクトのコンストラクターで、インスタンス オブジェクトの共通属性種を設定します。

コードをコピー コードは次のとおりです:
Function DOG(name){
this.name = 名前;
this.species = 'イヌ科';
}

次に、2 つのインスタンス オブジェクトを生成します:
コードをコピー コードは次のとおりです:
var DogA = new DOG('Big Hair');
var DogB = new DOG('二毛');

これら 2 つのオブジェクトの種属性は独立しており、一方を変更しても他方には影響しません。
コードをコピー コードは次のとおりです:
dogA.species = 'Feline';
alert(dogB.species); // 「犬」を表示します。dogA の影響を受けません

各インスタンス オブジェクトには、プロパティとメソッドの独自のコピーがあります。これではデータ共有が達成できないだけでなく、リソースの多大な浪費にもなります。

つまり: 継承の考え方: js の独自のプロトタイプ チェーンを通じて継承メカニズムを実装します。

4. プロトタイプチェーンに基づく継承

1. 直接継承の実装

コードをコピー コードは次のとおりです:
var Students = function(name, age, sid) {
person.call(this, 名前, 年齢);
This.sid = sid;
}
Students.prototype = new Person() // 継承メカニズムを実装するために、Student のプロトタイプ チェーンに person を配置します
Students.prototype.constructor = 学生;
Students.prototype.getResults = function() {
// 生徒のスコアを取得します
}

Students.prototype.constructor = Students という行を見逃さないようにしてください。 、コンストラクターを定義するとき、そのデフォルトのプロトタイプは Object インスタンスであり、プロトタイプのコンストラクター プロパティは自動的に関数自体に設定されます。 ! !プロトタイプを別のオブジェクトに手動で設定する場合、新しいオブジェクトは当然ながら元のオブジェクトのコンストラクター値を持たないため、そのコンストラクター プロパティをリセットする必要があります。例:
コードをコピー コードは次のとおりです。
var Test = function() {
This.time = "今";
}
console.log(Test.prototype); // オブジェクト {} 空のオブジェクト
console.log(Test.prototype.constructor); // function() {this.time = "now";} および関数自体
// Test
のプロトタイプ属性を手動で変更する場合 Test.prototype = {
SomeFunc: function() {
console.log('hello world!');
}
};
console.log(Test.prototype.constructor); // 関数 Object() { [ネイティブ コード] }
// その後、完全に間違った値を指定したことがわかります。そのため、プロトタイプ属性を手動で変更するときは、そのコンストラクター ポインタを変更する必要があります。 上記のテストの後、コンストラクターの値を変更する必要がある理由がわかります。

2. 継承された関数のカプセル化 extend


コードをコピーします コードは次のとおりです。function extend(subClass, superClass) {
var F = function() {};
F.prototype = superClass.prototype;
subClass.prototype = new F();
subClass.prototype.constructor = subClass;
}

実際、この関数の機能は上記の継承プロセスをカプセル化したものにすぎません。違いは次のとおりです。 superClass のプロトタイプ属性のみを継承し、superClass コンストラクターの属性は継承しません。
この利点は、新しいコンストラクターを作成するコストが削減されることです。
もちろん、後続の問題は、この関数だけではサブクラスがスーパークラスのすべての属性を継承できないことです
改善点:



コードをコピーします コードは次のとおりです: // Student コンストラクターにコード行を追加し続けます: person.call(this, 名前, 年齢);

5. まとめ

js のプロトタイプチェーン原理を使用すると、js の継承メカニズムを簡単に実装できます。それほど厳密ではありませんが、繰り返しコードをできるだけ 1 回出現させるという目標は達成されました。

この記事が皆様の JavaScript プログラミング設計に役立つことを願っています。

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C++関数継承の詳しい解説:継承で「基底クラスポインタ」と「派生クラスポインタ」を使うには? C++関数継承の詳しい解説:継承で「基底クラスポインタ」と「派生クラスポインタ」を使うには? May 01, 2024 pm 10:27 PM

関数の継承では、「基底クラス ポインター」と「派生クラス ポインター」を使用して継承メカニズムを理解します。基底クラス ポインターが派生クラス オブジェクトを指す場合、上方変換が実行され、基底クラスのメンバーのみにアクセスされます。派生クラス ポインターが基本クラス オブジェクトを指す場合、下向きキャストが実行される (安全ではない) ため、注意して使用する必要があります。

継承とポリモーフィズムは C++ のクラス結合にどのような影響を与えますか? 継承とポリモーフィズムは C++ のクラス結合にどのような影響を与えますか? Jun 05, 2024 pm 02:33 PM

継承とポリモーフィズムはクラスの結合に影響します。派生クラスは基本クラスに依存するため、継承により結合が増加します。ポリモーフィズムにより、オブジェクトは仮想関数と基本クラス ポインターを通じて一貫した方法でメッセージに応答できるため、結合が軽減されます。ベスト プラクティスには、継承を控えめに使用すること、パブリック インターフェイスを定義すること、基本クラスへのデータ メンバーの追加を回避すること、依存関係の注入を通じてクラスを分離することが含まれます。ポリモーフィズムと依存性注入を使用して銀行口座アプリケーションの結合を軽減する方法を示す実践的な例。

C++ 関数の継承の詳細な説明: 継承のエラーをデバッグするには? C++ 関数の継承の詳細な説明: 継承のエラーをデバッグするには? May 02, 2024 am 09:54 AM

継承エラーのデバッグのヒント: 正しい継承関係を確認します。デバッガーを使用してコードをステップ実行し、変数値を調べます。仮想修飾子を正しく使用してください。隠れた相続によって引き起こされる相続ダイアモンド問題を調べてください。抽象クラスに実装されていない純粋仮想関数がないか確認します。

C++ 関数の継承の説明: 継承を使用すべきでないのはどのような場合ですか? C++ 関数の継承の説明: 継承を使用すべきでないのはどのような場合ですか? May 04, 2024 pm 12:18 PM

C++ 関数の継承は、次の状況では使用しないでください。 派生クラスが異なる実装を必要とする場合、異なる実装を持つ新しい関数を作成する必要があります。派生クラスが関数を必要としない場合は、空のクラスとして宣言するか、プライベートの未実装の基本クラス メンバー関数を使用して関数の継承を無効にする必要があります。関数が継承を必要としない場合は、コードの再利用を実現するために他のメカニズム (テンプレートなど) を使用する必要があります。

C++ 関数の継承の詳細な説明: 継承における 'is-a' と 'has-a' の関係を理解するには? C++ 関数の継承の詳細な説明: 継承における 'is-a' と 'has-a' の関係を理解するには? May 02, 2024 am 08:18 AM

C++の関数継承を詳しく解説:「is-a」と「has-a」の関係をマスターしよう 関数継承とは?関数の継承は、派生クラスで定義されたメソッドを基本クラスで定義されたメソッドに関連付ける C++ の手法です。これにより、派生クラスが基本クラスのメソッドにアクセスしてオーバーライドできるようになり、基本クラスの機能が拡張されます。 「is-a」および「has-a」関係 関数継承では、「is-a」関係は、派生クラスが基本クラスのサブタイプであること、つまり、派生クラスが基本クラスの特性と動作を「継承」することを意味します。基本クラス。 「has-a」関係は、派生クラスに基本クラス オブジェクトへの参照またはポインターが含まれていること、つまり、派生クラスが基本クラス オブジェクトを「所有」していることを意味します。構文関数継承を実装する方法の構文は次のとおりです: classDerivedClass:pu

Golang 変数の保存場所とメカニズムの詳細な調査 Golang 変数の保存場所とメカニズムの詳細な調査 Feb 28, 2024 pm 09:45 PM

タイトル: Golang 変数の保存場所とメカニズムの詳細な調査 Go 言語 (Golang) の応用がクラウド コンピューティング、ビッグ データ、人工知能の分野で徐々に増加するにつれて、特に重要です。 Golang 変数の保存場所とメカニズムを深く理解します。この記事では、Golang における変数のメモリ割り当て、保存場所、および関連するメカニズムについて詳しく説明します。具体的なコード例を通じて、Golang 変数がメモリ内でどのように保存および管理されるかを読者がより深く理解できるようにします。 1.Golang変数の記憶

CSS レイアウトの再計算とレンダリングの仕組みを深く理解する CSS レイアウトの再計算とレンダリングの仕組みを深く理解する Jan 26, 2024 am 09:11 AM

CSS のリフローと再描画は、Web ページのパフォーマンスの最適化において非常に重要な概念です。 Web ページを開発する場合、これら 2 つの概念がどのように機能するかを理解すると、Web ページの応答速度とユーザー エクスペリエンスを向上させることができます。この記事では、CSS のリフローと再描画の仕組みを詳しく説明し、具体的なコード例を示します。 1. CSS リフローとは何ですか? DOM 構造内の要素の表示、サイズ、位置が変更されると、ブラウザは CSS スタイルを再計算して適用し、再レイアウトする必要があります。

「PHP によるオブジェクト指向プログラミング入門: 概念から実践まで」 「PHP によるオブジェクト指向プログラミング入門: 概念から実践まで」 Feb 25, 2024 pm 09:04 PM

オブジェクト指向プログラミングとは何ですか?オブジェクト指向プログラミング (OOP) は、現実世界のエンティティをクラスに抽象化し、オブジェクトを使用してこれらのエンティティを表すプログラミング パラダイムです。クラスはオブジェクトのプロパティと動作を定義し、オブジェクトはクラスをインスタンス化します。 OOP の主な利点は、コードの理解、保守、再利用が容易になることです。 OOP の基本概念 OOP の主な概念には、クラス、オブジェクト、プロパティ、メソッドが含まれます。クラスはオブジェクトの設計図であり、オブジェクトのプロパティと動作を定義します。オブジェクトはクラスのインスタンスであり、クラスのすべてのプロパティと動作を備えています。プロパティは、データを保存できるオブジェクトの特性です。メソッドは、オブジェクトのデータを操作できるオブジェクトの関数です。 OOP の利点 OOP の主な利点は次のとおりです。 再利用性: OOP はコードをより高度なものにすることができます。

See all articles