今回は「クラス」についてみていきます。
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 次回
さてだんだんと効率的になってきました。
次回は、さらにコードを少なくする工夫をしてみたいと思います。
カテゴリー
更新記事
- 『会社四季報 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
- JavaScript でオブジェクト 2
- JavaScript でオブジェクト 1
- JavaScript で関数 3
- JavaScript で関数 2
- JavaScript で関数 1
- JavaScript で配列 6
- JavaScript で配列 5
- JavaScript で配列 4
- テーマ株投資(3カ月目)
- JavaScript で配列 3
- JavaScript で配列 2
- JavaScript で配列 1
- JavaScript で「繰り返し」2
タグ
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) アンガーマネジメント (1) インソース (1) ココナラ (9) コーチング (1) チーズ (2) ネズミ (2) ノート (2) パーソルホールディングス (1) ブランディング (1) ブランド (1) プログリット (1) ポート (1) メモ (2) リスキリング (1) 変数 (3) 学習 (1) 小人 (2) 怒り (1) 株式 (18) 睡眠 (3) 給水器 (1) 記憶 (3) Aoba-BBT (9) IGS (9) Kラーニング (1)