検索
ホームページウェブフロントエンドjsチュートリアルJavaScript 継承の使用法分析_js オブジェクト指向

JavaScript の継承について詳しく学ぶ前に、まず次の概念を理解してください:
親クラス: 継承されたクラス
サブクラス: 継承されたクラス
スーパー クラス: つまり、親クラス
抽象クラス: A通常はインスタンス化に使用されないクラス。その目的は他のクラスから継承することです。
基底クラス: 他のクラスが継承できるクラス
派生クラス: 基底クラスから継承されるクラス

JavaScript オブジェクトの継承には通常、次の 5 つのメソッドがあります:
1. オブジェクトの偽装
2. call() メソッド
3. apply() メソッド
4. プロトタイプ チェーン
5.混合メソッド

A. オブジェクトの偽装
いわゆるオブジェクトの偽装とは、継承の目的を達成するために、新しいクラスが古いクラスを偽装することです (古いクラスはコンストラクター メソッドを使用する必要があります)。例 .1

コードをコピー コードは次のとおりです:
function people(name,sex) ,age){ // コンストラクター メソッドを使用します。
this.name=name;
this.say=function(){
alert(" 私の名前は "
};

this.doing=function(){
alert("私は話しています");
}
var Marry=new people("Marry","Woman","23");
Marry.doing(); White_people(名前, 性別, 年齢){
this.inherit=people;
this.inherit を削除

this.area= function(){
alert("私はヨーロッパにいます");
}
}
var Tom=newwhite_people("トム","男","21"); Tom.say( );
Tom.area();
alert(Tom.age);


上記の例では、people がwhite_people の基本クラスとして使用されていることに注意してください。形式は
this.inherit=people で、継承を実現するためにオブジェクトの偽装に使用されます。 //Inherit
delete this.inherit; /継承の削除
親クラスの関連する属性とメソッドの上書きを避けるために、すべての新しい属性と新しいメソッドを削除する必要があります。
さらに、オブジェクトの偽装は多重継承をサポートします。 2



コードをコピーします


コードは次のとおりです。


function worker(pay,work){
this.pay= pay;
this.work=work; function city_worker(name,sex,age,pay,work){ this.inherit=people; >this.inherit(名前、性別、年齢); this.inherit; this.inherit(pay,work);継承; }
var Jerry=new city_worker("Jerry","man","21","$1000","coder"); >alert(Jerry.work) ;


オブジェクトの偽装には欠点があります。多重継承メカニズムが実装されている場合、基本クラスが同じ属性またはメソッドを持つ場合、後続のクラスから継承されてしまいます。 .

B.call () メソッド
は、カプセル化されたオブジェクトによって偽装された単なる関数です。このように、「古典的な」 3 つの文を記述する必要はなくなり、次の文に置き換えます。文:
Base class.call(object,parameters List)
eg.1




コードをコピー


コードは次のとおりです

function farmer(name,sex,age,pay,work){
people.call(this,name,sex,age);
worker.call(this) ,pay,work);
}

var Nicholas=new farmer("Nicholas","man","27","$3000","irrigator"); );
alert(Nicholas.pay);
同様に、call() には、同じ名前のプロパティとメソッドに関する小さな問題があります。メソッド call() と同じです。apply() もオブジェクト偽装のラッパー関数です。形式は次のとおりです: base class.apply(object,parameter array);
コードをコピー


コードは次のとおりです:


function White_collar(name,sex,age,pay,work) ){
people.apply(this,new Array(name,sex,age));
worker.apply(this,[pay,work]);

var Jiessie =newwhite_collar("Jiessie","女性","26","$2500","editor");
Jiessie.say()
alert(Jiessie.work);
同様に、apply() には同じ名前のプロパティとメソッドに関する小さな問題があります。

D. プロトタイプ チェーン
同様に、上記の 3 つのメソッドはすべてコンストラクターの形式で継承を使用します。
eg.1
コードをコピー コードは次のとおりです。 :

function blue_collar(){
}
blue_collar.prototype.name="ジーン";
blue_collar.prototype.age="33";プロトタイプ.say=function(){
alert("私の名前は "
);

function city_blue_collar(){
}
city_blue_collar.prototype=新しいブルーカラー();

var jj=新しいシティ_ブルー_カラー

;
The prototype chain also has the disadvantages of the prototype chain: parameters cannot be passed. In addition, the prototype chain does not support multiple inheritance, because

E. Mixed method
uses the constructor method to write the attributes of the class, For inheritance of attributes, use call() or apply()
Use prototype method to write methods, for inheritance of methods, use prototype chain
eg.1
Copy code The code is as follows:

function beauty(name,age){
this.name=name;
this.age=age;
}
beauty.prototype.say=function(){
alert("Little girl's name" this.name);
};

function china_beauty(name,age,area ){
beauty.call(this,name,age);
this.area=area;
}
china_beauty.prototype=new beauty();
china_beauty.prototype.from= function(){
alert("I am from" this.area);
};

var diaochan=new china_beauty("Diao Chan","16","Lintao");
diaochan.say();
diaochan.from();
alert(diaochan.age);
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
JavaScriptの起源:その実装言語の調査JavaScriptの起源:その実装言語の調査Apr 29, 2025 am 12:51 AM

JavaScriptは1995年に発信され、Brandon Ikeによって作成され、言語をCに実現しました。 2。JavaScriptのメモリ管理とパフォーマンスの最適化は、C言語に依存しています。 3. C言語のクロスプラットフォーム機能は、さまざまなオペレーティングシステムでJavaScriptを効率的に実行するのに役立ちます。

舞台裏:JavaScriptをパワーする言語は何ですか?舞台裏:JavaScriptをパワーする言語は何ですか?Apr 28, 2025 am 12:01 AM

JavaScriptはブラウザとnode.js環境で実行され、JavaScriptエンジンに依存してコードを解析および実行します。 1)解析段階で抽象的構文ツリー(AST)を生成します。 2)ASTをコンパイル段階のバイトコードまたはマシンコードに変換します。 3)実行段階でコンパイルされたコードを実行します。

PythonとJavaScriptの未来:傾向と予測PythonとJavaScriptの未来:傾向と予測Apr 27, 2025 am 12:21 AM

PythonとJavaScriptの将来の傾向には、1。Pythonが科学コンピューティングの分野での位置を統合し、AI、2。JavaScriptはWebテクノロジーの開発を促進します。どちらもそれぞれのフィールドでアプリケーションシナリオを拡大し続け、パフォーマンスをより多くのブレークスルーを行います。

Python vs. JavaScript:開発環境とツールPython vs. JavaScript:開発環境とツールApr 26, 2025 am 12:09 AM

開発環境におけるPythonとJavaScriptの両方の選択が重要です。 1)Pythonの開発環境には、Pycharm、Jupyternotebook、Anacondaが含まれます。これらは、データサイエンスと迅速なプロトタイピングに適しています。 2)JavaScriptの開発環境には、フロントエンドおよびバックエンド開発に適したnode.js、vscode、およびwebpackが含まれます。プロジェクトのニーズに応じて適切なツールを選択すると、開発効率とプロジェクトの成功率が向上する可能性があります。

JavaScriptはCで書かれていますか?証拠を調べるJavaScriptはCで書かれていますか?証拠を調べるApr 25, 2025 am 12:15 AM

はい、JavaScriptのエンジンコアはCで記述されています。1)C言語は、JavaScriptエンジンの開発に適した効率的なパフォーマンスと基礎となる制御を提供します。 2)V8エンジンを例にとると、そのコアはCで記述され、Cの効率とオブジェクト指向の特性を組み合わせて書かれています。3)JavaScriptエンジンの作業原理には、解析、コンパイル、実行が含まれ、C言語はこれらのプロセスで重要な役割を果たします。

JavaScriptの役割:WebをインタラクティブでダイナミックにするJavaScriptの役割:WebをインタラクティブでダイナミックにするApr 24, 2025 am 12:12 AM

JavaScriptは、Webページのインタラクティブ性とダイナミズムを向上させるため、現代のWebサイトの中心にあります。 1)ページを更新せずにコンテンツを変更できます。2)Domapiを介してWebページを操作する、3)アニメーションやドラッグアンドドロップなどの複雑なインタラクティブ効果、4)ユーザーエクスペリエンスを改善するためのパフォーマンスとベストプラクティスを最適化します。

CおよびJavaScript:接続が説明しましたCおよびJavaScript:接続が説明しましたApr 23, 2025 am 12:07 AM

CおよびJavaScriptは、WebAssemblyを介して相互運用性を実現します。 1)CコードはWebAssemblyモジュールにコンパイルされ、JavaScript環境に導入され、コンピューティングパワーが強化されます。 2)ゲーム開発では、Cは物理エンジンとグラフィックスレンダリングを処理し、JavaScriptはゲームロジックとユーザーインターフェイスを担当します。

Webサイトからアプリまで:JavaScriptの多様なアプリケーションWebサイトからアプリまで:JavaScriptの多様なアプリケーションApr 22, 2025 am 12:02 AM

JavaScriptは、Webサイト、モバイルアプリケーション、デスクトップアプリケーション、サーバー側のプログラミングで広く使用されています。 1)Webサイト開発では、JavaScriptはHTMLおよびCSSと一緒にDOMを運用して、JQueryやReactなどのフレームワークをサポートします。 2)ReactNativeおよびIonicを通じて、JavaScriptはクロスプラットフォームモバイルアプリケーションを開発するために使用されます。 3)電子フレームワークにより、JavaScriptはデスクトップアプリケーションを構築できます。 4)node.jsを使用すると、JavaScriptがサーバー側で実行され、高い並行リクエストをサポートします。

See all articles

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SublimeText3 中国語版

SublimeText3 中国語版

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

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。