TypeScript - Kelas

TypeScript adalah JavaScript berorientasi objek. TypeScript mendukung fitur pemrograman berorientasi objek seperti kelas, antarmuka, dll. Kelas dalam istilah OOP adalah cetak biru untuk membuat objek. Kelas merangkum data untuk objek tersebut. Typecript memberikan dukungan bawaan untuk konsep ini yang disebut class. JavaScript ES5 atau sebelumnya tidak mendukung kelas. Ketik mendapatkan fitur ini dari ES6.

Membuat kelas

Gunakan kata kunci class untuk mendeklarasikan kelas di TypeScript. Sintaks yang sama diberikan di bawah ini -

Sintaksis

class class_name { 
   //class scope 
}

Kata kunci kelas diikuti dengan nama kelas. Aturan untuk pengidentifikasi harus dipertimbangkan saat memberi nama kelas.

Definisi kelas dapat mencakup yang berikut -

  • Fields- Bidang adalah variabel apa pun yang dideklarasikan di kelas. Bidang mewakili data yang berkaitan dengan objek

  • Constructors - Bertanggung jawab untuk mengalokasikan memori untuk objek kelas

  • Functions- Fungsi mewakili tindakan yang dapat dilakukan suatu objek. Mereka juga kadang-kadang disebut sebagai metode

Komponen-komponen ini disatukan disebut sebagai anggota data kelas.

Pertimbangkan orang kelas dalam naskah ketikan.

class Person {
}

Saat kompilasi, itu akan menghasilkan kode JavaScript berikut.

//Generated by typescript 1.8.10
var Person = (function () {
   function Person() {
   }
   return Person;
}());

Contoh: Mendeklarasikan kelas

class Car { 
   //field 
   engine:string; 
 
   //constructor 
   constructor(engine:string) { 
      this.engine = engine 
   }  

   //function 
   disp():void { 
      console.log("Engine is  :   "+this.engine) 
   } 
}

Contoh mendeklarasikan mobil kelas. Kelas memiliki bidang bernama mesin. Ituvarkata kunci tidak digunakan saat mendeklarasikan bidang. Contoh di atas mendeklarasikan konstruktor untuk kelas.

Konstruktor adalah fungsi khusus kelas yang bertanggung jawab untuk menginisialisasi variabel kelas. TypeScript mendefinisikan konstruktor menggunakan kata kunci konstruktor. Konstruktor adalah sebuah fungsi dan karenanya dapat dijadikan parameter.

Itu thisKata kunci mengacu pada contoh kelas saat ini. Di sini, nama parameter dan nama bidang kelas sama. Karenanya untuk menghindari ambiguitas, bidang kelas diawali denganthis kata kunci.

disp () adalah definisi fungsi sederhana. Perhatikan bahwa kata kunci fungsi tidak digunakan di sini.

Saat kompilasi, itu akan menghasilkan kode JavaScript berikut.

//Generated by typescript 1.8.10
var Car = (function () {
   //constructor
   function Car(engine) {
      this.engine = engine;
   }
	
   //function
   Car.prototype.disp = function () {
      console.log("Engine is  :   " + this.engine);
   };
   return Car;
}());

Membuat objek Instance

Untuk membuat instance kelas, gunakan newkata kunci diikuti dengan nama kelas. Sintaks yang sama diberikan di bawah ini -

Sintaksis

var object_name = new class_name([ arguments ])
  • Itu new kata kunci bertanggung jawab untuk instantiation.

  • Sisi kanan ekspresi memanggil konstruktor. Konstruktor harus diberi nilai jika berparameter.

Contoh: Membuat instance kelas

var obj = new Car("Engine 1")

Mengakses Atribut dan Fungsi

Atribut dan fungsi kelas dapat diakses melalui objek. Menggunakan ' . 'notasi titik (disebut periode) untuk mengakses data anggota kelas.

//accessing an attribute 
obj.field_name 

//accessing a function 
obj.function_name()

Contoh: Menyatukannya

class Car { 
   //field 
   engine:string; 
   
   //constructor 
   constructor(engine:string) { 
      this.engine = engine 
   }  
   
   //function 
   disp():void { 
      console.log("Function displays Engine is  :   "+this.engine) 
   } 
} 

//create an object 
var obj = new Car("XXSY1")

//access the field 
console.log("Reading attribute value Engine as :  "+obj.engine)  

//access the function
obj.disp()

Saat kompilasi, itu akan menghasilkan kode JavaScript berikut.

//Generated by typescript 1.8.10
var Car = (function () {
   //constructor
   function Car(engine) {
      this.engine = engine;
   }
	
   //function
   Car.prototype.disp = function () {
      console.log("Function displays Engine is  :   " + this.engine);
   };
   return Car;
}());

//create an object
var obj = new Car("XXSY1");

//access the field
console.log("Reading attribute value Engine as :  " + obj.engine);

//access the function
obj.disp();

Output dari kode diatas adalah sebagai berikut -

Reading attribute value Engine as :  XXSY1 
Function displays Engine is  :   XXSY1

Warisan Kelas

TypeScript mendukung konsep Inheritance. Pewarisan adalah kemampuan program untuk membuat kelas baru dari kelas yang sudah ada. Kelas yang diperluas untuk membuat kelas yang lebih baru disebut kelas induk / kelas super. Kelas yang baru dibuat disebut anak / sub kelas.

Sebuah kelas mewarisi dari kelas lain menggunakan kata kunci 'meluas'. Kelas anak mewarisi semua properti dan metode kecuali anggota pribadi dan konstruktor dari kelas induk.

Sintaksis

class child_class_name extends parent_class_name

Namun, TypeScript tidak mendukung multiple inheritance.

Contoh: Warisan Kelas

class Shape { 
   Area:number 
   
   constructor(a:number) { 
      this.Area = a 
   } 
} 

class Circle extends Shape { 
   disp():void { 
      console.log("Area of the circle:  "+this.Area) 
   } 
}
  
var obj = new Circle(223); 
obj.disp()

Saat kompilasi, itu akan menghasilkan kode JavaScript berikut.

//Generated by typescript 1.8.10
var __extends = (this && this.__extends) || function (d, b) {
   for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
   function __() { this.constructor = d; }
   d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
var Shape = (function () {
   function Shape(a) {
      this.Area = a;
   }
   return Shape;
}());

var Circle = (function (_super) {
   __extends(Circle, _super);
   function Circle() {
      _super.apply(this, arguments);
   }
	
   Circle.prototype.disp = function () { 
      console.log("Area of the circle:  " + this.Area); 
   };
   return Circle;
}(Shape));

var obj = new Circle(223);
obj.disp();

Output dari kode diatas adalah sebagai berikut -

Area of the Circle: 223

Contoh di atas mendeklarasikan Shape kelas. Kelas diperluas oleh kelas Lingkaran. Karena ada hubungan warisan antara kelas, kelas anak yaitu kelas Mobil mendapat akses implisit ke atribut kelas induknya yaitu area.

Warisan dapat diklasifikasikan sebagai -

  • Single - Setiap kelas maksimal dapat diperluas dari satu kelas induk

  • Multiple- Kelas dapat mewarisi dari beberapa kelas. TypeScript tidak mendukung multiple inheritance.

  • Multi-level - Contoh berikut menunjukkan cara kerja warisan multi-level.

Contoh

class Root { 
   str:string; 
} 

class Child extends Root {} 
class Leaf extends Child {} //indirectly inherits from Root by virtue of inheritance  

var obj = new Leaf(); 
obj.str ="hello" 
console.log(obj.str)

Kelas Leaf memperoleh atribut dari kelas Root dan Child berdasarkan pewarisan multi-level.

Saat kompilasi, itu akan menghasilkan kode JavaScript berikut.

//Generated by typescript 1.8.10
var __extends = (this && this.__extends) || function (d, b) {
   for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
   function __() { this.constructor = d; }
   d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};

var Root = (function () {
   function Root() {
   }
   return Root;
}());

var Child = (function (_super) {
   __extends(Child, _super);
   function Child() {
      _super.apply(this, arguments);
   }
   return Child;
}(Root));

var Leaf = (function (_super) {
   __extends(Leaf, _super);
   function Leaf() {
      _super.apply(this, arguments);
   }
   return Leaf;
}(Child));

var obj = new Leaf();
obj.str = "hello";
console.log(obj.str);

Outputnya adalah sebagai berikut -

Keluaran

hello

TypeScript ─ Warisan kelas dan Penimpaan Metode

Method Overriding adalah mekanisme dimana kelas anak mendefinisikan ulang metode kelas super. Contoh berikut menggambarkan hal yang sama -

class PrinterClass { 
   doPrint():void {
      console.log("doPrint() from Parent called…") 
   } 
} 

class StringPrinter extends PrinterClass { 
   doPrint():void { 
      super.doPrint() 
      console.log("doPrint() is printing a string…")
   } 
} 

var obj = new StringPrinter() 
obj.doPrint()

Kata kunci super digunakan untuk merujuk ke induk langsung dari sebuah kelas. Kata kunci dapat digunakan untuk merujuk ke versi kelas super dari variabel, properti, atau metode. Baris 13 memanggil versi kelas super dari fungsi doWork ().

Saat kompilasi, itu akan menghasilkan kode JavaScript berikut.

//Generated by typescript 1.8.10
var __extends = (this && this.__extends) || function (d, b) {
   for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
   function __() { this.constructor = d; }
   d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};

var PrinterClass = (function () {
   function PrinterClass() {
   }
   PrinterClass.prototype.doPrint = function () { 
      console.log("doPrint() from Parent called…"); 
   };
   return PrinterClass;
}());

var StringPrinter = (function (_super) {
   __extends(StringPrinter, _super);
	
   function StringPrinter() {
      _super.apply(this, arguments);
   }
	
   StringPrinter.prototype.doPrint = function () {
      _super.prototype.doPrint.call(this);
      console.log("doPrint() is printing a string…");
   };
	
   return StringPrinter;
}(PrinterClass));

var obj = new StringPrinter();
obj.doPrint();

Output dari kode diatas adalah sebagai berikut -

doPrint() from Parent called… 
doPrint() is printing a string…

Kata Kunci statis

Kata kunci statis dapat diterapkan ke anggota data kelas. Variabel statis mempertahankan nilainya sampai program menyelesaikan eksekusi. Anggota statis direferensikan dengan nama kelas.

Contoh

class StaticMem {  
   static num:number; 
   
   static disp():void { 
      console.log("The value of num is"+ StaticMem.num) 
   } 
} 

StaticMem.num = 12     // initialize the static variable 
StaticMem.disp()      // invoke the static method

Saat kompilasi, itu akan menghasilkan kode JavaScript berikut.

//Generated by typescript 1.8.10
var StaticMem = (function () {
   function StaticMem() {
   }
	
   StaticMem.disp = function () {
      console.log("The value of num is" + StaticMem.num);
   };
	
   return StaticMem;
}());

StaticMem.num = 12;     // initialize the static variable
StaticMem.disp();      // invoke the static method

Output dari kode diatas adalah sebagai berikut -

The value of num is 12

Contoh operator

Itu instanceof operator mengembalikan nilai true jika objek milik tipe yang ditentukan.

Contoh

class Person{ } 
var obj = new Person() 
var isPerson = obj instanceof Person; 
console.log(" obj is an instance of Person " + isPerson);

Saat kompilasi, itu akan menghasilkan kode JavaScript berikut.

//Generated by typescript 1.8.10
var Person = (function () {
   function Person() {
   }
   return Person;
}());

var obj = new Person();
var isPerson = obj instanceof Person;
console.log(" obj is an instance of Person " + isPerson);

Output dari kode diatas adalah sebagai berikut -

obj is an instance of Person True

Menyembunyikan Data

Kelas dapat mengontrol visibilitas anggota datanya ke anggota kelas lain. Kemampuan ini disebut sebagai Penyembunyian Data atau Enkapsulasi.

Orientasi Objek menggunakan konsep pengubah akses atau penentu akses untuk mengimplementasikan konsep Enkapsulasi. Penentu / pengubah akses menentukan visibilitas anggota data kelas di luar kelas yang menentukan.

Pengubah akses yang didukung oleh TypeScript adalah -

S.No. Access Specifier & Description
1.

public

Anggota data publik memiliki aksesibilitas universal. Anggota data di kelas bersifat publik secara default.

2.

private

Anggota data pribadi hanya dapat diakses dalam kelas yang menetapkan anggota ini. Jika anggota kelas eksternal mencoba mengakses anggota privat, kompilator akan membuat kesalahan.

3.

protected

Anggota data yang dilindungi dapat diakses oleh anggota dalam kelas yang sama seperti sebelumnya dan juga oleh anggota kelas anak.

Contoh

Sekarang mari kita ambil contoh untuk melihat cara kerja penyembunyian data -

class Encapsulate { 
   str:string = "hello" 
   private str2:string = "world" 
}
 
var obj = new Encapsulate() 
console.log(obj.str)     //accessible 
console.log(obj.str2)   //compilation Error as str2 is private

Kelas memiliki dua atribut string, str1 dan str2, yang masing-masing merupakan anggota publik dan pribadi. Kelas dibuat. Contoh mengembalikan kesalahan waktu kompilasi, karena atribut privat str2 diakses di luar kelas yang mendeklarasikannya.

Kelas dan Antarmuka

Kelas juga dapat mengimplementasikan antarmuka.

interface ILoan { 
   interest:number 
} 

class AgriLoan implements ILoan { 
   interest:number 
   rebate:number 
   
   constructor(interest:number,rebate:number) { 
      this.interest = interest 
      this.rebate = rebate 
   } 
} 

var obj = new AgriLoan(10,1) 
console.log("Interest is : "+obj.interest+" Rebate is : "+obj.rebate )

Kelas AgriLoan mengimplementasikan Pinjaman antarmuka. Oleh karena itu, sekarang mengikat kelas untuk menyertakan propertiinterest sebagai anggotanya.

Saat kompilasi, itu akan menghasilkan kode JavaScript berikut.

//Generated by typescript 1.8.10
var AgriLoan = (function () {
   function AgriLoan(interest, rebate) {
      this.interest = interest;
      this.rebate = rebate;
   }
   return AgriLoan;
}());

var obj = new AgriLoan(10, 1);
console.log("Interest is : " + obj.interest + " Rebate is : " + obj.rebate);

Output dari kode diatas adalah sebagai berikut -

Interest is : 10 Rebate is : 1