ホームページ ウェブフロントエンド jsチュートリアル JSオブジェクト指向プログラミング オブジェクト利用分析_JavaScriptスキル

JSオブジェクト指向プログラミング オブジェクト利用分析_JavaScriptスキル

May 16, 2016 pm 06:21 PM
オブジェクト指向

誰もが常にプロセス指向のプログラミングのアイデアを使用して JS コードを記述しており、インターネットにはあまりにも多くの小さな「賢い」 JS コード スニペット (その多くはランダムで非常に不規則なもの) が溢れているため、これがすべての人に「誤解」を引き起こしています。 JS はあくまで小さな補助ツールであり、大きなものの開発には向いていないということです。しかし、AJAX の台頭以来​​、大量の JS コードを記述するには、JAVA のようなコードを記述するのと同じようにオブジェクト指向開発ができる必要があります。

以下では、私自身の経験と学んだことを組み合わせて、JS でオブジェクト指向プログラミングを使用する方法を学習します。実際、JS の各関数は次の関数のようにオブジェクトであるため、オブジェクト指向開発に JS を使用することは難しくありません。

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

function HelloWorld()
{
alert('hello world!')
}

次に、次のテスト関数を使用するなど、使用時にオブジェクトとして使用できます:
コードをコピー コードは次のとおりです:

function _test()
{
var obj = new HelloWorld()
}

次に呼び出します。 _test メソッド すると、Hello World がポップアップ表示されます。プロンプト ボックス、つまり HelloWorld() オブジェクト (関数) が呼び出されます。ここの HelloWorld オブジェクトにはプロパティやメソッドがありません。HelloWorld() というメソッドが 1 つだけあります。 new を使用してオブジェクトを作成すると、それは Its と呼ばれます。施工方法。これは最も単純なオブジェクトでもあります。もちろん、JS では、値を割り当てるために、prototype キーワードを使用します。たとえば、HelloWorld オブジェクトに、sayHello メソッドと name 属性を追加します。
コードをコピー コードは次のとおりです:

HelloWorld.prototype = {
name : 'JavaScript',
sayHello : function() {
alert(this.name)
}
}

次に、HelloWorld にすることができます。 name 属性と SayHello メソッドを追加しました。_test メソッドを次のように変更しましょう:
コードをコピー コードは次のとおりです。

function _test()
{
var obj = new HelloWorld();
obj.sayHello();
_test メソッドを呼び出した後、hello wordl! と JavaScript が連続して出力されます (1 つは構築メソッドのアラートで、もう 1 つはsayHello メソッドのアラートです)。 SayHello メソッドのアラートは this キーワードを参照することに注意してください。このキーワードは HelloWorld オブジェクトを表し、JAVA の this キーワードと同様に、デフォルトでこのオブジェクトを指します。
インスタンス メソッドとプロパティをオブジェクトに追加するには、上記の方法を使用します。つまり、prototype キーワードを使用して値を割り当てます。形式は次のとおりです:

オブジェクト名.prototype。 = {
プロパティ 1: 属性値、
属性 2: 属性値、
メソッド 1: 関数 (パラメーター リスト) {
メソッド本体;
}、
メソッド 2: 関数(パラメータリスト) {
メソッド本体;
}
}

上記のように、オブジェクトに複数のプロパティとメソッドを定義できるため、オブジェクトを新規作成した後にインスタンスを使用できますname.property またはプロパティを取得するかメソッドを実行するメソッド。

上記のメソッドでは、オブジェクトの属性に直接アクセスできないことをご存じないかもしれません。たとえば、HelloWorld オブジェクトの name 属性にアクセスするには、obj.name を使用して直接取得できます。これは JAVA の public 属性に似ており、name 属性に値を直接割り当てることもできます。ここで疑問が生じます。プライベート メンバー変数をオブジェクトに割り当てるにはどうすればよいでしょうか?その場合、HelloWorld クラスの宣言方法を変更する必要があるかもしれません。プロトタイプを使用してクラスの属性とメソッドを宣言する代わりに、インライン関数と属性を直接使用して宣言します。変更された HelloWorld は次のようになり、HelloWorld2 と名付けられます。



コードをコピー コードは次のとおりです。 function HelloWorld2()
{
var privateProp = ' hello world 2!';
this.method = function() {
alert(privateProp)
}
}


HelloWorld2のクラス宣言メソッドを見たことがありますか?関数のネスト宣言は関数内で直接行われ、プライベート メンバー変数であるローカル変数 privateProp も設定されます。この変数は HelloWorld2 内の関数からのみアクセスできるため、外部アクセスは許可されません。変数のスコープを使用してクラスのプライベート変数を取得します。私たちのアプリケーションは次のとおりです:
コードをコピー コードは次のとおりです:

function _test2( )
{
var obj2 = new HelloWorld2();
obj2.method(); // このメソッドを呼び出すと 'hello world 2!
alert(obj2.privateProp); print unknown
}

上記は、クラスの定義方法と、クラスの属性とメソッドの定義方法についてです。プロトタイプ メソッドを使用すると定義が明確になるため、これを行います。メソッドは通常、クラスの定義に使用され、同様のクラス宣言メソッドが多くの AJAX フレームワークで使用されています。さらに、クラスのプライベート メンバ変数には、クラスの構築メソッド内の関数からしかアクセスできません。このように、クラスのプロトタイプで宣言されたメソッドはプライベート メンバ変数にアクセスできず、可読性が劣ります。プロトタイプメソッドとして。

わかりました。上記はすべて、クラスのインスタンス メソッドと属性の定義に関するものです。 JAVA では、クラスはインスタンスのメソッドとプロパティ、およびクラスのメソッドとプロパティに分割されます。いわゆるクラス属性とメソッドは、クラスのすべてのインスタンスが、インスタンスごとにセットを保持するのではなく、クラス属性とクラス メソッドのコピーのみを保持することを意味します。これは、インスタンス属性やインスタンス メソッドとは異なります。では、JS でクラスの静的クラス メソッドとクラス属性を定義するにはどうすればよいでしょうか?静的属性と静的メソッドをクラスに直接追加できます。たとえば、age 静的属性と hello 静的メソッドを HelloWorld クラスに追加すると、宣言は次のようになります。
コードをコピーします
コードは次のとおりです: HelloWorld.age = 22; HelloWorld.hello = function() {
alert (HelloWorld.age);
}


次に、クラス HelloWorld に対して静的属性 age と静的メソッド hello が宣言されます。これを使用する場合、クラス名を使用して直接アクセスできますが、インスタンスを使用してアクセスすることはできません。テストは次のとおりです。



コードをコピーします var obj = new HelloWorld(); SayHello(); // 正しい、インスタンス メソッド。インスタンスを通じてアクセスできます。
HelloWorld.hello() // 正しい、静的メソッド。クラス名を通じて直接アクセスできます。
obj.hello();エラー。インスタンスの静的メソッドを通じてアクセスできません。 JS エラーが報告されます。
}


上記の説明を通じて、皆さんは JS を使用したオブジェクト指向プログラミングについてある程度の理解があり、始める準備ができていると思います。 a try~~ (注: 上記のコードはすべてテストに合格しました!)
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Go言語を使用してオブジェクト指向のイベント駆動型プログラミングを実装する方法 Go言語を使用してオブジェクト指向のイベント駆動型プログラミングを実装する方法 Jul 20, 2023 pm 10:36 PM

Go 言語を使用してオブジェクト指向イベント駆動プログラミングを実装する方法 はじめに: オブジェクト指向プログラミング パラダイムはソフトウェア開発で広く使用されており、イベント駆動プログラミングは、トリガーと処理を通じてプログラム フローを実現する一般的なプログラミング モデルです。イベント、コントロール。この記事では、Go 言語を使用してオブジェクト指向のイベント駆動型プログラミングを実装する方法とコード例を紹介します。 1. イベント駆動型プログラミングの概念 イベント駆動型プログラミングは、プログラムのフロー制御をイベントのトリガーと処理に移す、イベントとメッセージに基づくプログラミング モデルです。イベント駆動型で

Java で Jackson を使用する @JsonIdentityInfo アノテーションの重要性は何ですか? Java で Jackson を使用する @JsonIdentityInfo アノテーションの重要性は何ですか? Sep 23, 2023 am 09:37 AM

@JsonIdentityInfo アノテーションは、Jackson ライブラリ内でオブジェクトに親子関係がある場合に使用されます。 @JsonIdentityInfo アノテーションは、シリアル化および逆シリアル化中にオブジェクトの ID を示すために使用されます。 ObjectIdGenerators.PropertyGenerator は、使用されるオブジェクト識別子が POJO プロパティから取得される状況を表すために使用される抽象プレースホルダー クラスです。構文@Target(value={ANNOTATION_TYPE,TYPE,FIELD,METHOD,PARAMETER})@Retention(value=RUNTIME)public

Go でオブジェクト指向プログラミングを探索する Go でオブジェクト指向プログラミングを探索する Apr 04, 2024 am 10:39 AM

Go 言語は、型定義とメソッドの関連付けを通じてオブジェクト指向プログラミングをサポートします。従来の継承はサポートされていませんが、合成を通じて実装されます。インターフェイスは型間の一貫性を提供し、抽象メソッドを定義できるようにします。実際の事例では、顧客操作の作成、取得、更新、削除など、OOP を使用して顧客情報を管理する方法を示します。

PHP オブジェクト指向プログラミングにおけるフライウェイト パターンの分析 PHP オブジェクト指向プログラミングにおけるフライウェイト パターンの分析 Aug 14, 2023 pm 05:25 PM

PHP オブジェクト指向プログラミングにおけるフライウェイト パターンの分析 オブジェクト指向プログラミングでは、デザイン パターンは一般的に使用されるソフトウェア設計手法であり、コードの可読性、保守性、スケーラビリティを向上させることができます。フライウェイト パターンは、オブジェクトを共有することでメモリのオーバーヘッドを削減する設計パターンの 1 つです。この記事では、PHP でフライウェイト モードを使用してプログラムのパフォーマンスを向上させる方法を説明します。フライ級モードとは何ですか?フライウェイト パターンは、異なるオブジェクト間で同じオブジェクトを共有することを目的とした構造設計パターンです。

PHP の高度な機能: オブジェクト指向プログラミングのベスト プラクティス PHP の高度な機能: オブジェクト指向プログラミングのベスト プラクティス Jun 05, 2024 pm 09:39 PM

PHP における OOP のベスト プラクティスには、命名規則、インターフェイスと抽象クラス、継承とポリモーフィズム、依存関係の注入が含まれます。実際のケースには、ウェアハウス モードを使用してデータを管理する場合や、ストラテジー モードを使用して並べ替えを実装する場合などがあります。

Go言語のオブジェクト指向機能の分析 Go言語のオブジェクト指向機能の分析 Apr 04, 2024 am 11:18 AM

Go 言語は、オブジェクト指向プログラミング、構造体によるオブジェクトの定義、ポインター レシーバーを使用したメソッドの定義、インターフェイスによるポリモーフィズムの実装をサポートしています。オブジェクト指向の機能は、Go 言語でのコードの再利用、保守性、カプセル化を提供しますが、クラスや継承、メソッド シグネチャ キャストといった従来の概念が欠如しているなどの制限もあります。

Golang にはクラスのようなオブジェクト指向機能はありますか? Golang にはクラスのようなオブジェクト指向機能はありますか? Mar 19, 2024 pm 02:51 PM

Golang (Go 言語) には伝統的な意味でのクラスの概念はありませんが、構造体と呼ばれるデータ型が提供され、これによってクラスと同様のオブジェクト指向機能を実現できます。この記事では、構造体を使用してオブジェクト指向機能を実装する方法を説明し、具体的なコード例を示します。構造体の定義と使用法 まず、構造体の定義と使用法を見てみましょう。 Golang では、type キーワードを通じて構造を定義し、必要に応じて使用できます。構造には属性を含めることができます

PHP オブジェクト指向プログラミングの深い理解: オブジェクト指向プログラミングのデバッグ手法 PHP オブジェクト指向プログラミングの深い理解: オブジェクト指向プログラミングのデバッグ手法 Jun 05, 2024 pm 08:50 PM

オブジェクトのステータスの追跡、ブレークポイントの設定、例外の追跡を習得し、xdebug 拡張機能を利用することで、PHP オブジェクト指向プログラミング コードを効果的にデバッグできます。 1. オブジェクトのステータスを追跡する: var_dump() と print_r() を使用して、オブジェクトの属性とメソッドの値を表示します。 2. ブレークポイントの設定: 開発環境にブレークポイントを設定すると、実行がブレークポイントに到達するとデバッガが一時停止するため、オブジェクトのステータスを簡単に確認できます。 3. 例外のトレース: try-catch ブロックと getTraceAsString() を使用して、例外発生時のスタック トレースとメッセージを取得します。 4. デバッガーを使用します。xdebug_var_dump() 関数は、コードの実行中に変数の内容を検査できます。

See all articles