今回は「クラス」についてみていきます。
1 オブジェクト
オブジェクトにはさまざまなプロパティやメソッドを定義することができ、したがって単なる変数よりも、情報を整理して格納することができます。
しかし、次のような場合はどうでしょうか。
HTML(一部)
<script>
let tr1 = {
name : "三角形",
base : 6,
height : 8,
calcArea : function() {
return ( this.base * this.height ) / 2 ;
}
}
let tr2 = {
name : "さんかくけい",
base : 8,
height : 12,
calcArea : function() {
return ( this.base * this.height ) / 2 ;
}
}
let tr3 = {
name : "トライアングル",
base : 8,
height : 14,
calcArea : function() {
return ( this.base * this.height ) / 2 ;
}
}
let area1 = tr1.calcArea();
let area2 = tr2.calcArea();
let area3 = tr3.calcArea();
document.write("<p>" + tr1.name + "の面積は" + area1 + "です。</p>");
document.write("<p>" + tr2.name + "の面積は" + area2 + "です。</p>");
document.write("<p>" + tr3.name + "の面積は" + area3 + "です。</p>");
</script>
ブラウザ
この例では定義の時点で値を入力しています。(さらに行数が増えるのを避けるためです。)
このように3つのオブジェクトを定義してそれぞれ表示するだけでも、これだけの行数を要します。
これまで、変数や繰り返し処理など、できるだけ少ないコードで処理を行うことに努めてきましたが、このオブジェクトの定義についても何とかならないのでしょうか?
2 クラス
そこで「クラス」というものを利用します。
書式
class クラスの名前{
メソッドの名前(引数){
引数の処理
}
}
もちろん、メソッドの名前や引数は複数記述することができます。
なお、クラスは「オブジェクトを設計するもの」であるということができます。
HTML(一部)
<script>
class Tri{
constructor(name, base, height){ // ① コンストラクタ
this.name = name;
this.base = base;
this.height = height;
}
calcArea() { // ② メソッド
return ( this.base * this.height ) / 2 ;
}
}
tr1 = new Tri("三角形", 6, 8); // ③ インスタンスを生成
tr2 = new Tri("さんかくけい", 8, 12);
tr3 = new Tri("トライアングル", 8, 14);
let area1 = tr1.calcArea(); // ④ 計算結果を代入
let area2 = tr2.calcArea();
let area3 = tr3.calcArea();
document.write("<p>" + tr1.name + "の面積は" + area1 + "です。</p>");
document.write("<p>" + tr2.name + "の面積は" + area2 + "です。</p>");
document.write("<p>" + tr3.name + "の面積は" + area3 + "です。</p>");
</script>
ブラウザ
コードを少なくすることができました。
生成されたオブジェクトが3つなので大した効果がないかもしれませんが、これが何十、何百のオフジェクトを生成する場合には大きく違ってきます。
3 クラスの定義とインスタンスの生成
上から みていきます。
HTML(一部)
class Tri{
constructor(name, base, height){
this.name = name;
this.base = base;
this.height = height;
}
calcArea() {
return ( this.base * this.height ) / 2 ;
}
}
「おや?」と思われた方、その通りです。
オブジェクトではなく、constructor という特殊なメソッドで定義されていますね。
HTML(一部)
tr1 = new Tri("三角形", 6, 8);
そして、次の箇所では new クラス名 でオブジェクトを作っています。
この生成されたオブジェクトのことを インスタンス といいます。
HTML(一部)
constructor(name, base, height){
this.name = name; ①
this.base = base; ②
this.height = height; ③
}
・
・ ↑
・
tr1 = new Tri("三角形", 6, 8); ① ② ③
このインスタンスを生成する動きをわかりやすくすると上のようになります。
まず、インスタンスを生成するときに、constructor メソッドが呼び出され、引数として指定されている、① “三角形” が name に、② 6 が base に、そして、③ 8 が height にそれぞれ代入されます。
これが コンストラクタ の役割で、クラスからインスタンスを生成する際に呼び出されるメソッドです。
これらのプロパティを持つオブジェクトが tr1 となります。
メソッドについては前回説明したとおりの動きですね。
今回の例では、これが3回繰り返されます。
4 次回
さてだんだんと効率的になってきました。
次回は、さらにコードを少なくする工夫をしてみたいと思います。
カテゴリー
更新記事
- 『日本経済新聞』を読む 2(DAC、株主優待、オピオイド、ベトナム車市場、離れ小島)
- 『日本経済新聞』を読む 1(リバースメンタリング、CBT、EBPM、地方創生DAO、IBD)
- テーマ株投資(7か月)
- 『会社四季報 2024年 3集 夏号』を読む 20(RPF、DtoC、ToF、駅ナカ、CX)
- 『会社四季報 2024年 3集 夏号』を読む 19(ATC、プローブカード、ニューデリー、商品CFD、SUV、FPC、IFRS)
- 『会社四季報 2024年 3集 夏号』を読む 18(シャリ玉ロボット、YAGレーザー、シナジー、SaaS、クルーズ、DFBレーザー)
- 『会社四季報 2024年 3集 夏号』を読む 17(DSP、サーメタル、自動小銃、ダイカストマシン、FPSO、サーボモーター、水晶振動子)
- 『会社四季報 2024年 3集 夏号』を読む 16(クロスセル、eVTOL、CFCC、RFID、配当性向、事業承継)
- 『会社四季報 2024年 3集 夏号』を読む 15(SiC半導体、NAS電池、フェロニッケル、フェライト粉、スポンジチタン)
- 『会社四季報 2024年 3集 夏号』を読む 14(AI警備システム、プロダクトアウト、ホットメルト接着剤、放熱ゲル、パイル、カソード)
- 『会社四季報 2024年 3集 夏号』を読む 13(PLM、ファクタリング、BCP、グリシン、メタクリル樹脂、アクティブシニア)
- テーマ株投資(6か月)
- 『会社四季報 2024年 3集 夏号』を読む 12(カプロラクタム、ゼロトラスト、RAG、ERP、シリカ)
- 『会社四季報 2024年 3集 夏号』を読む 11(オリゴマー、エッジAI、MLCC、ジルコニウム、アセチレンガス、ファインケミカル)
- 『会社四季報 2024年 3集 夏号』を読む 10(フラッシュハンドル、自動配膳ロボット、R-SUD、レコメンド機能、マーチャンダイジング、エレクトロニクスガス、コーシャ認証)
- 『会社四季報 2024年 3集 夏号』を読む 9(ペロブスカイト太陽電池、プロテイン、銀だこ、尿素SCR、エクソソーム)
- 『会社四季報 2024年 3集 夏号』を読む 8(ドミナント、EBITDA、SAF、消防車、キャンプ用品、GIGAスクール、ボウリング場)
- 『会社四季報 2024年 3集 夏号』を読む 7(MD、パーム椰子、GMS、EC、デジタルサイネージ、ハラール認証、ヴィーガンコスメ)
- 『会社四季報 2024年 3集 夏号』を読む 6(BIM、CMS、つけまつげ、CDMO、BNPL、EDI、CRM)
- 『会社四季報 2024年 3集 夏号』を読む 5(アグリゲーション、EMS、BPO、のれん、カカオ豆、オーツミルク)
- 『会社四季報 2024年 3集 夏号』を読む 4(SEP、社内起業、ZEP、VPP、DOE、バイオセンサー、PBX)
- 『会社四季報 2024年 3集 夏号』を読む 3(海上油田、シェールオイル、カーボンクレジット、キャッシュフロー経営、軽量気泡コンクリート、医療観光、洋上風力発電)
- テーマ株投資(5か月)
- 『会社四季報 2024年 3集 夏号』を読む 2
- 『会社四季報 2024年 3集 夏号』を読む 1
- JavaScript でDOM 2
- JavaScript でDOM 1
- JavaScript でオブジェクト 5
- JavaScript でオブジェクト 4
- JavaScript でオブジェクト 3
タグ
break (1) class (3) collection (6) continue (1) CSS (2) DOM (2) for (1) function (3) HTML (8) if (2) JavaScript (28) object (5) pop (1) push (1) shift (1) switch (1) unshift (1) VBA (1) while (2) ことば (2) アンガーマネジメント (1) インソース (1) ココナラ (11) コーチング (1) チーズ (2) ネズミ (2) ノート (2) パーソルホールディングス (3) ブランディング (1) ブランド (1) プログリット (1) ポート (1) メモ (2) リスキリング (1) リンクアンドモチベーション (2) 変数 (3) 学習 (1) 小人 (2) 怒り (1) 株式 (29) 睡眠 (3) 給水器 (1) 記憶 (3) Aoba-BBT (11) IGS (11) Kラーニング (1)