TypeScript - Fungsi
Fungsi adalah elemen dasar dari kode yang dapat dibaca, dipelihara, dan dapat digunakan kembali. Fungsi adalah sekumpulan pernyataan untuk melakukan tugas tertentu. Fungsi mengatur program menjadi blok-blok kode logis. Setelah ditentukan, fungsi dapat dipanggil ke kode akses. Ini membuat kode dapat digunakan kembali. Selain itu, fungsi memudahkan untuk membaca dan memelihara kode program.
Deklarasi fungsi memberi tahu kompiler tentang nama fungsi, tipe kembalian, dan parameter. Definisi fungsi memberikan tubuh sebenarnya dari fungsi tersebut.
Sr Tidak | Fungsi & Deskripsi |
---|---|
1. | Mendefinisikan Fungsi Definisi fungsi menentukan apa dan bagaimana tugas tertentu akan dilakukan. |
2. | Memanggil Fungsi Sebuah fungsi harus dipanggil untuk menjalankannya. |
3. | Fungsi Kembali Fungsi juga dapat mengembalikan nilai bersama dengan kontrol, kembali ke pemanggil. |
4. | Fungsi Parameter Parameter adalah mekanisme untuk meneruskan nilai ke fungsi. |
Parameter Opsional
Parameter opsional dapat digunakan saat argumen tidak perlu diteruskan secara wajib untuk eksekusi fungsi. Sebuah parameter dapat ditandai opsional dengan menambahkan tanda tanya ke namanya. Parameter opsional harus ditetapkan sebagai argumen terakhir dalam suatu fungsi. Sintaks untuk mendeklarasikan fungsi dengan parameter opsional seperti yang diberikan di bawah ini -
function function_name (param1[:type], param2[:type], param3[:type])
Contoh: Parameter Opsional
function disp_details(id:number,name:string,mail_id?:string) {
console.log("ID:", id);
console.log("Name",name);
if(mail_id!=undefined)
console.log("Email Id",mail_id);
}
disp_details(123,"John");
disp_details(111,"mary","[email protected]");
Contoh di atas mendeklarasikan fungsi berparameter. Di sini, parameter ketiga, yaitu mail_id adalah parameter opsional.
Jika parameter opsional tidak melewati nilai selama pemanggilan fungsi, nilai parameter disetel ke tidak ditentukan.
Fungsi mencetak nilai mail_id hanya jika argumen diberikan nilai.
Saat kompilasi, itu akan menghasilkan kode JavaScript berikut -
//Generated by typescript 1.8.10
function disp_details(id, name, mail_id) {
console.log("ID:", id);
console.log("Name", name);
if (mail_id != undefined)
console.log("Email Id", mail_id);
}
disp_details(123, "John");
disp_details(111, "mary", "[email protected]");
Kode di atas akan menghasilkan keluaran sebagai berikut -
ID:123
Name John
ID: 111
Name mary
Email Id [email protected]
Parameter Istirahat
Parameter istirahat mirip dengan argumen variabel di Java. Parameter istirahat tidak membatasi jumlah nilai yang dapat Anda berikan ke suatu fungsi. Namun, semua nilai yang diteruskan harus berjenis sama. Dengan kata lain, parameter rest bertindak sebagai placeholder untuk beberapa argumen dengan tipe yang sama.
Untuk mendeklarasikan parameter istirahat, nama parameter diawali dengan tiga titik. Semua parameter nonrest harus diletakkan sebelum parameter rest.
Contoh: Parameter Istirahat
function addNumbers(...nums:number[]) {
var i;
var sum:number = 0;
for(i = 0;i<nums.length;i++) {
sum = sum + nums[i];
}
console.log("sum of the numbers",sum)
}
addNumbers(1,2,3)
addNumbers(10,10,10,10,10)
The addNumbers function () deklarasi, menerima sisa parameter nums . Tipe data parameter lainnya harus disetel ke larik. Selain itu, suatu fungsi dapat memiliki paling banyak satu parameter istirahat.
Fungsi tersebut dipanggil dua kali, dengan melewatkan tiga dan enam nilai, masing-masing.
Perulangan for melakukan iterasi melalui daftar argumen, diteruskan ke fungsi dan menghitung jumlahnya.
Saat kompilasi, itu akan menghasilkan kode JavaScript berikut -
function addNumbers() {
var nums = [];
for (var _i = 0; _i < arguments.length; _i++) {
nums[_i - 0] = arguments[_i];
}
var i;
var sum = 0;
for (i = 0; i < nums.length; i++) {
sum = sum + nums[i];
}
console.log("sum of the numbers", sum);
}
addNumbers(1, 2, 3);
addNumbers(10, 10, 10, 10, 10);
Output dari kode di atas adalah sebagai berikut -
sum of numbers 6
sum of numbers 50
Parameter Default
Parameter fungsi juga dapat diberi nilai secara default. Namun, parameter tersebut juga dapat secara eksplisit memberikan nilai.
Sintaksis
function function_name(param1[:type],param2[:type] = default_value) {
}
Note - Parameter tidak dapat dinyatakan opsional dan default pada saat yang bersamaan.
Contoh: Parameter default
function calculate_discount(price:number,rate:number = 0.50) {
var discount = price * rate;
console.log("Discount Amount: ",discount);
}
calculate_discount(1000)
calculate_discount(1000,0.30)
Saat kompilasi, itu akan menghasilkan kode JavaScript berikut -
//Generated by typescript 1.8.10
function calculate_discount(price, rate) {
if (rate === void 0) { rate = 0.50; }
var discount = price * rate;
console.log("Discount Amount: ", discount);
}
calculate_discount(1000);
calculate_discount(1000, 0.30);
Outputnya adalah sebagai berikut -
Discount amount : 500
Discount amount : 300
Contoh mendeklarasikan fungsi, count_discount . Fungsi ini memiliki dua parameter - harga dan tarif.
Nilai tingkat parameter diatur ke 0,50 secara default.
Program ini memanggil fungsi, hanya meneruskan nilai dari harga parameter. Di sini, nilai rate adalah 0,50 (default)
Fungsi yang sama dipanggil, tetapi dengan dua argumen. Nilai default rate ditimpa dan disetel ke nilai yang diteruskan secara eksplisit.
Fungsi Anonim
Fungsi yang tidak terikat ke pengenal (nama fungsi) disebut sebagai anonymous functions. Fungsi ini dideklarasikan secara dinamis pada waktu proses. Fungsi anonim dapat menerima masukan dan mengembalikan keluaran, seperti halnya fungsi standar. Fungsi anonim biasanya tidak dapat diakses setelah pembuatan awal.
Variabel dapat diberi fungsi anonim. Ekspresi seperti itu disebut ekspresi fungsi.
Sintaksis
var res = function( [arguments] ) { ... }
Contoh ─ Fungsi Anonim Sederhana
var msg = function() {
return "hello world";
}
console.log(msg())
Saat kompilasi, itu akan menghasilkan kode yang sama di JavaScript.
Ini akan menghasilkan keluaran sebagai berikut -
hello world
Contoh ─ Fungsi anonim dengan parameter
var res = function(a:number,b:number) {
return a*b;
};
console.log(res(12,2))
Fungsi anonim mengembalikan produk dari nilai yang diteruskan padanya.
Saat kompilasi, itu akan menghasilkan kode JavaScript berikut -
//Generated by typescript 1.8.10
var res = function (a, b) {
return a * b;
};
console.log(res(12, 2));
Output dari kode di atas adalah sebagai berikut -
24
Ekspresi Fungsi dan Deklarasi Fungsi ─ Apakah keduanya identik?
Ekspresi fungsi dan deklarasi fungsi tidak sama. Tidak seperti ekspresi fungsi, deklarasi fungsi terikat oleh nama fungsi.
Perbedaan mendasar antara keduanya adalah, deklarasi fungsi diurai sebelum dieksekusi. Di sisi lain, ekspresi fungsi diurai hanya ketika mesin skrip menemukannya selama eksekusi.
Saat pengurai JavaScript melihat sebuah fungsi dalam alur kode utama, ia mengasumsikan Deklarasi Fungsi. Ketika fungsi datang sebagai bagian dari pernyataan, itu adalah Ekspresi Fungsi.
Pembuat Fungsi
TypeScript juga mendukung penetapan fungsi dengan konstruktor JavaScript bawaan yang disebut Function ().
Sintaksis
var res = new Function( [arguments] ) { ... }.
Contoh
var myFunction = new Function("a", "b", "return a * b");
var x = myFunction(4, 3);
console.log(x);
Fungsi baru () adalah panggilan ke konstruktor yang pada gilirannya membuat dan mengembalikan referensi fungsi.
Saat kompilasi, itu akan menghasilkan kode yang sama di JavaScript.
Output dari kode contoh di atas adalah sebagai berikut -
12
Fungsi Rekursi dan TypeScript
Rekursi adalah teknik untuk melakukan iterasi atas suatu operasi dengan memiliki pemanggilan fungsi ke dirinya sendiri berulang kali hingga mencapai hasil. Rekursi paling baik diterapkan saat Anda perlu memanggil fungsi yang sama berulang kali dengan parameter berbeda dari dalam satu loop.
Contoh - Rekursi
function factorial(number) {
if (number <= 0) { // termination case
return 1;
} else {
return (number * factorial(number - 1)); // function invokes itself
}
};
console.log(factorial(6)); // outputs 720
Saat kompilasi, itu akan menghasilkan kode yang sama di JavaScript.
Ini hasilnya -
720
Contoh: Fungsi Rekursif Anonim
(function () {
var x = "Hello!!";
console.log(x)
})() // the function invokes itself using a pair of parentheses ()
Saat kompilasi, itu akan menghasilkan kode yang sama di JavaScript.
Outputnya adalah sebagai berikut -
Hello!!
Fungsi Lambda
Lambda mengacu pada fungsi anonim dalam pemrograman. Fungsi Lambda adalah mekanisme ringkas untuk merepresentasikan fungsi anonim. Fungsi ini juga disebut sebagaiArrow functions.
Fungsi Lambda - Anatomi
Ada 3 bagian untuk fungsi Lambda -
Parameters - Suatu fungsi secara opsional memiliki parameter
The fat arrow notation/lambda notation (=>) - Ini juga disebut sebagai pergi ke operator
Statements - mewakili set instruksi fungsi
Tip - Secara konvensi, penggunaan parameter huruf tunggal didorong untuk deklarasi fungsi yang ringkas dan tepat.
Ekspresi Lambda
Ini adalah ekspresi fungsi anonim yang menunjuk ke satu baris kode. Sintaksnya adalah sebagai berikut -
( [param1, parma2,…param n] )=>statement;
Contoh: Ekspresi Lambda
var foo = (x:number)=>10 + x
console.log(foo(100)) //outputs 110
Program ini mendeklarasikan fungsi ekspresi lambda. Fungsi mengembalikan jumlah 10 dan argumen diteruskan.
Saat kompilasi, itu akan menghasilkan kode JavaScript berikut.
//Generated by typescript 1.8.10
var foo = function (x) { return 10 + x; };
console.log(foo(100)); //outputs 110
Berikut adalah keluaran dari kode di atas -
110
Pernyataan Lambda
Pernyataan Lambda adalah deklarasi fungsi anonim yang menunjuk ke blok kode. Sintaks ini digunakan saat badan fungsi mencakup beberapa baris. Sintaksnya adalah sebagai berikut -
( [param1, parma2,…param n] )=> {
//code block
}
Contoh: Pernyataan Lambda
var foo = (x:number)=> {
x = 10 + x
console.log(x)
}
foo(100)
Referensi fungsi dikembalikan dan disimpan dalam variabel foo.
Saat kompilasi, itu akan menghasilkan kode JavaScript berikut -
//Generated by typescript 1.8.10
var foo = function (x) {
x = 10 + x;
console.log(x);
};
foo(100);
Output dari program di atas adalah sebagai berikut -
110
Variasi Sintaksis
Jenis parameter Inferensi
Tidak wajib menentukan tipe data parameter. Dalam kasus seperti itu, tipe data parameternya adalah apa saja. Mari kita lihat cuplikan kode berikut -
var func = (x)=> {
if(typeof x=="number") {
console.log(x+" is numeric")
} else if(typeof x=="string") {
console.log(x+" is a string")
}
}
func(12)
func("Tom")
Saat kompilasi, itu akan menghasilkan kode JavaScript berikut -
//Generated by typescript 1.8.10
var func = function (x) {
if (typeof x == "number") {
console.log(x + " is numeric");
} else if (typeof x == "string") {
console.log(x + " is a string");
}
};
func(12);
func("Tom");
Outputnya adalah sebagai berikut -
12 is numeric
Tom is a string
Tanda kurung opsional untuk satu parameter
var display = x=> {
console.log("The function got "+x)
}
display(12)
Saat kompilasi, itu akan menghasilkan kode JavaScript berikut -
//Generated by typescript 1.8.10
var display = function (x) {
console.log("The function got " + x);
};
display(12);
Outputnya adalah sebagai berikut -
The function got 12
Tanda kurung opsional untuk pernyataan tunggal, Tanda kurung kosong untuk tidak ada parameter
Contoh berikut menunjukkan dua variasi Sintaksis ini.
var disp =()=> {
console.log("Function invoked");
}
disp();
Saat kompilasi, itu akan menghasilkan kode JavaScript berikut -
//Generated by typescript 1.8.10
var disp = function () {
console.log("Function invoked");
};
disp();
Outputnya adalah sebagai berikut -
Function invoked
Kelebihan Fungsi
Fungsi memiliki kemampuan untuk beroperasi secara berbeda berdasarkan masukan yang diberikan kepadanya. Dengan kata lain, suatu program dapat memiliki beberapa metode dengan nama yang sama dengan implementasi yang berbeda. Mekanisme ini disebut sebagai Function Overloading. TypeScript memberikan dukungan untuk kelebihan beban fungsi.
Untuk membebani suatu fungsi di TypeScript, Anda harus mengikuti langkah-langkah yang diberikan di bawah ini -
Step 1- Menyatakan beberapa fungsi dengan nama yang sama tetapi tanda tangan fungsi berbeda. Tanda tangan fungsi meliputi yang berikut ini.
The data type of the parameter
function disp(string):void;
function disp(number):void;
The number of parameters
function disp(n1:number):void;
function disp(x:number,y:number):void;
The sequence of parameters
function disp(n1:number,s1:string):void;
function disp(s:string,n:number):void;
Note - Tanda tangan fungsi tidak menyertakan tipe kembalian fungsi.
Step 2- Deklarasi tersebut harus diikuti oleh definisi fungsi. Jenis parameter harus disetel keanyjika jenis parameter berbeda selama kelebihan beban. Selain itu, untukcase b dijelaskan di atas, Anda dapat mempertimbangkan untuk menandai satu atau lebih parameter sebagai opsional selama definisi fungsi.
Step 3 - Terakhir, Anda harus menjalankan fungsi agar berfungsi.
Contoh
Sekarang mari kita lihat kode contoh berikut -
function disp(s1:string):void;
function disp(n1:number,s1:string):void;
function disp(x:any,y?:any):void {
console.log(x);
console.log(y);
}
disp("abc")
disp(1,"xyz");
Dua baris pertama menggambarkan deklarasi kelebihan beban fungsi. Fungsi ini memiliki dua kelebihan -
Fungsi yang menerima parameter string tunggal.
Fungsi yang menerima dua nilai masing-masing tipe number dan string.
Baris ketiga mendefinisikan fungsinya. Jenis data dari parameter diatur keany. Selain itu, parameter kedua bersifat opsional di sini.
Fungsi kelebihan beban dipanggil oleh dua pernyataan terakhir.
Saat kompilasi, itu akan menghasilkan kode JavaScript berikut -
//Generated by typescript 1.8.10
function disp(x, y) {
console.log(x);
console.log(y);
}
disp("abc");
disp(1, "xyz");
Kode di atas akan menghasilkan keluaran sebagai berikut -
abc
1
xyz