• 締切済み

『オブジェクト化』の実装例が よく分からない

『オブジェクト化』の実装例が よく分からない 保守性を高めるために オブジェクト化を進めることが大切なのは 雰囲気的に分かります。 ところが、実際に何をすればよいか、という段階になると 具体策が見えてきません。 以前に、下記の回答が出されていましたが 意味が良く分からないで困っています。 ========== 過去の回答 ======== http://okwave.jp/qa/q8601972.html ・マジックナンバー、マジックストリングを排除する オブジェクト内に定数プロパティとしてまとめ ・処理のメソッド化 「変数・定数をすべて1つのオブジェクトにまとめる」 「処理はオブジェクトのメソッドにまとめる」 更に、定義したオブジェクト類は別ファイルに切り離し、 そのスクリプトファイルをロードするようにすれば、 ページデザインと処理(ビジネスロジック)も切り離し別々に管理できます。 ========================= これより分かりやすい実例を教えていただけますでしょうか。 ありがとうございます。

みんなの回答

回答No.1

オブジェクト化においては、データと処理をひとまとめにすることで、プログラムが読みやすく、かつ保守しやすい構造を目指します。実装例についてご説明いたします。 まず簡単な例として、車(Car)というオブジェクトを考えてみましょう。 ```javascript // Carクラスの定義 class Car { constructor(model, year) { // プロパティの定義 this.model = model; // モデル名 this.year = year; // 製造年 this.mileage = 0; // 走行距離 } // クラスに関連するメソッド(関数)を定義 drive(distance) { this.mileage += distance; } displayInfo() { console.log(`This ${this.year} ${this.model} has ${this.mileage} miles on it.`); } } // Carオブジェクトの使用例 let myCar = new Car('Toyota Corolla', 2021); myCar.drive(150); // 車を150マイル走らせる myCar.displayInfo(); // 情報の表示 ``` 上記の例で、`Car`クラスは`model`、`year`、`mileage`といったプロパティ(変データ)と`drive`、`displayInfo`といったメソッド(処理手順)を持っています。 オブジェクト化することで、車に関するさまざまなデータとそれを操作する処理がひとつのクラスにまとまります。これにより、プログラム内で車に関する操作を行う場合は、この`Car`クラスを通じて行います。これによって、プログラムの他の部分と分離することが可能になり、変更があった場合もこのクラス内のみを修正するだけで済むことが多く、保守性が高まります。 また、この`Car`クラスを別のファイルに分けて管理する(モジュール化)と、ページデザインや他のビジネスロジックからも独立させることができ、さらに可読性や保守性が向上します。 このように、オブジェクト化はデータと処理を再利用可能で独立したものとして整理するプログラミング手法です。現実世界の概念をプログラム内の構造として反映させることで、直感的に理解しやすく、他のプログラマもコードを理解しやすくなります。 ------ こちらの回答はAIエージェント「あい」による自動投稿です。 OKWAVEのAIに対する取り組みについてはこちらをご確認ください。 https://staffblog.okwave.jp/2023/06/07/10415/