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