ES6 - Fungsi

Functionsadalah blok bangunan kode yang dapat dibaca, dipelihara, dan dapat digunakan kembali. Fungsi ditentukan menggunakan kata kunci fungsi. Berikut ini adalah sintaks untuk mendefinisikan fungsi standar.

function function_name() { 
   // function body 
}

Untuk memaksa eksekusi fungsi, itu harus dipanggil. Ini disebut sebagai pemanggilan fungsi. Berikut adalah sintaks untuk memanggil suatu fungsi.

function_name()

Contoh: Definisi fungsi sederhana

//define a  function 
function test() { 
   console.log("function called") 
} 
//call the function 
test()

Contoh ini mendefinisikan tes fungsi (). Sepasang pembatas ({}) mendefinisikan badan fungsi. Itu juga disebut sebagaifunction scope. Sebuah fungsi harus dipanggil untuk memaksa eksekusinya.

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

function called

Klasifikasi Fungsi

Fungsi dapat diklasifikasikan sebagai Returning dan Parameterized fungsi.

Mengembalikan fungsi

Fungsi juga dapat mengembalikan nilai bersama dengan kontrol, kembali ke pemanggil. Fungsi seperti itu disebut sebagai fungsi balik.

Berikut ini adalah sintaks untuk fungsi yang kembali.

function function_name() { 
   //statements 
   return value; 
}
  • Fungsi pengembalian harus diakhiri dengan pernyataan pengembalian.

  • Suatu fungsi dapat mengembalikan paling banyak satu nilai. Dengan kata lain, hanya ada satu pernyataan pengembalian per fungsi.

  • Pernyataan return harus menjadi pernyataan terakhir dalam fungsi tersebut.

Potongan kode berikut adalah contoh dari fungsi kembali -

function retStr() { 
   return "hello world!!!" 
}  
var val = retStr() 
console.log(val)

Contoh di atas mendefinisikan fungsi yang mengembalikan string "hello world !!!" ke penelepon. Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

hello world!!!

Fungsi parameter

Parameter adalah mekanisme untuk meneruskan nilai ke fungsi. Parameter merupakan bagian dari tanda tangan fungsi. Nilai parameter diteruskan ke fungsi selama pemanggilannya. Kecuali ditentukan secara eksplisit, jumlah nilai yang diteruskan ke fungsi harus cocok dengan jumlah parameter yang ditentukan.

Berikut ini adalah sintaks yang mendefinisikan fungsi berparameter.

function func_name( param1,param2 ,…..paramN) {   
   ...... 
   ...... 
}

Example − Parameterized Function

Contoh mendefinisikan penambahan fungsi yang menerima dua parameter n1 dan n2dan mencetak jumlahnya. Nilai parameter diteruskan ke fungsi saat dipanggil.

function add( n1,n2) { 
   var sum = n1 + n2 
   console.log("The sum of the values entered "+sum) 
} 
add(12,13)

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

The sum of the values entered 25

Parameter fungsi default

Dalam ES6, suatu fungsi memungkinkan parameter untuk diinisialisasi dengan nilai default, jika tidak ada nilai yang diteruskan atau tidak ditentukan. Hal yang sama diilustrasikan dalam kode berikut.

function add(a, b = 1) { 
   return a+b; 
} 
console.log(add(4))

Fungsi di atas, menetapkan nilai b ke 1 secara default. Fungsi tersebut akan selalu mempertimbangkan parameter b untuk menanggung nilai 1 kecuali nilai telah diteruskan secara eksplisit. Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

5

Nilai default parameter akan ditimpa jika fungsi meneruskan nilai secara eksplisit.

function add(a, b = 1) { 
   return a + b; 
} 
console.log(add(4,2))

Kode di atas menetapkan nilai parameter b secara eksplisit ke 2, sehingga menimpa nilai defaultnya. Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

6

Untuk pemahaman yang lebih baik, mari kita perhatikan contoh di bawah ini.

Contoh 1

Contoh berikut menunjukkan fungsi yang mengambil dua parameter dan mengembalikan jumlahnya. Parameter kedua memiliki nilai default 10. Artinya, jika tidak ada nilai yang dikirimkan ke parameter kedua, nilainya menjadi 10.

<script>
   function addTwoNumbers(first,second = 10){
      console.log('first parameter is :',first)
      console.log('second parameter is :',second)
      return first+second;
   }

   console.log("case 1 sum:",addTwoNumbers(20)) // no value
   console.log("case 2 sum:",addTwoNumbers(2,3))
   console.log("case 3 sum:",addTwoNumbers())
   console.log("case 4 sum",addTwoNumbers(1,null))//null passed
   console.log("case 5 sum",addTwoNumbers(3,undefined))
</script>

Output dari kode di atas akan seperti yang disebutkan di bawah ini -

first parameter is : 20
second parameter is : 10
case 1 sum: 30
first parameter is : 2
second parameter is : 3
case 2 sum: 5
first parameter is : undefined
second parameter is : 10
case 3 sum: NaN
first parameter is : 1
second parameter is : null
case 4 sum 1
first parameter is : 3
second parameter is : 10
case 5 sum 13

Contoh 2

<script>
   let DEFAULT_VAL = 30
      function addTwoNumbers(first,second = DEFAULT_VAL){
         console.log('first parameter is :',first)
         console.log('second parameter is :',second)
         return first+second;
      }
      console.log("case 1 sum",addTwoNumbers(1))
      console.log("case 2 sum",addTwoNumbers(3,undefined))
</script>

Output dari kode di atas akan seperti gambar di bawah ini -

first parameter is : 1
second parameter is : 30
case 1 sum 31
first parameter is : 3
second parameter is : 30
case 2 sum 33

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, yang dikenal sebagai operator sebaran. Contoh berikut menggambarkan hal yang sama.

function fun1(...params) { 
   console.log(params.length); 
}  
fun1();  
fun1(5); 
fun1(5, 6, 7);

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

0 
1 
3

Note - Parameter istirahat harus menjadi yang terakhir dalam daftar parameter fungsi.

Fungsi Anonim

Fungsi yang tidak terikat ke pengenal (nama fungsi) disebut sebagai fungsi anonim. 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 afunction expression.

Berikut ini adalah sintaks untuk fungsi anonim.

var res = function( [arguments] ) { ... }

Example − Anonymous Function

var f = function(){ return "hello"} 
console.log(f())

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

hello

Example − Anonymous Parameterized Function

var func = function(x,y){ return x*y }; 
function product() { 
   var result; 
   result = func(10,20); 
   console.log("The product : "+result) 
} 
product()

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

The product : 200

Pembuat Fungsi

Pernyataan fungsi bukan satu-satunya cara untuk mendefinisikan fungsi baru; Anda bisa mendefinisikan fungsi Anda secara dinamis menggunakan konstruktor Function () bersama dengan operator baru.

Berikut adalah sintaks untuk membuat fungsi menggunakan konstruktor Function () bersama dengan operator baru.

var variablename = new Function(Arg1, Arg2..., "Function Body");

Konstruktor Function () mengharapkan sejumlah argumen string. Argumen terakhir adalah badan fungsi - dapat berisi pernyataan JavaScript yang berubah-ubah, dipisahkan satu sama lain dengan titik koma.

Konstruktor Function () tidak memberikan argumen apa pun yang menentukan nama untuk fungsi yang dibuatnya.

Example − Function Constructor

var func = new Function("x", "y", "return x*y;"); 
function product() { 
   var result; 
   result = func(10,20); 
   console.log("The product : "+result)
} 
product()

Dalam contoh di atas, konstruktor Function () digunakan untuk mendefinisikan fungsi anonim. Fungsi tersebut menerima dua parameter dan mengembalikan produknya.

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

The product : 200

Fungsi Rekursi dan JavaScript

Rekursi adalah teknik untuk melakukan iterasi pada suatu operasi dengan memiliki pemanggilan fungsi itu 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.

Example − Recursion

function factorial(num) { 
   if(num <= 0) { 
      return 1; 
   } else { 
      return (num * factorial(num-1)  ) 
   } 
} 
console.log(factorial(6))

Dalam contoh di atas, fungsi memanggil dirinya sendiri. Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

720

Example − Anonymous Recursive Function

(function() { 
   var msg = "Hello World" 
   console.log(msg)
})()

Fungsi tersebut memanggil dirinya sendiri menggunakan sepasang tanda kurung (). Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

Hello World

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.

  • Itu fat arrow notation/lambda notation (=>): Ini juga disebut sebagai operator pergi ke.

  • Statements - Mewakili set instruksi fungsi.

Tip - Sesuai kesepakatan, penggunaan parameter huruf tunggal dianjurkan untuk deklarasi fungsi yang kompak dan tepat.

Ekspresi Lambda

Ini adalah ekspresi fungsi anonim yang menunjuk ke satu baris kode. Berikut ini adalah sintaks yang sama.

([param1, parma2,…param n] )=>statement;

Example − Lambda Expression

var foo = (x)=>10+x 
console.log(foo(10))

Contoh mendeklarasikan fungsi ekspresi lambda. Fungsi mengembalikan jumlah 10 dan argumen diteruskan.

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

20

Pernyataan Lambda

Ini adalah deklarasi fungsi anonim yang menunjuk ke blok kode. Sintaks ini digunakan ketika badan fungsi mencakup beberapa baris. Berikut ini adalah sintaks yang sama.

( [param1, parma2,…param n] )=> {       
   //code block 
}

Example − Lambda Statement

var msg = ()=> { 
   console.log("function invoked") 
} 
msg()

Referensi fungsi dikembalikan dan disimpan dalam variabel msg. Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

function  invoked

Variasi Sintaksis

Tanda kurung opsional untuk satu parameter.

var msg = x=> { 
   console.log(x) 
} 
msg(10)

Kawat gigi opsional untuk satu pernyataan. Tanda kurung kosong jika tidak ada parameter.

var disp = ()=>console.log("Hello World") 
disp();

Ekspresi Fungsi dan Deklarasi Fungsi

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 saat mesin skrip menemukannya selama eksekusi.

Saat pengurai JavaScript melihat sebuah fungsi dalam alur kode utama, ia mengasumsikan deklarasi fungsi. Ketika sebuah fungsi muncul sebagai bagian dari pernyataan, itu adalah ekspresi fungsi.

Fungsi Mengangkat

Seperti variabel, fungsi juga bisa diangkat. Tidak seperti variabel, deklarasi fungsi saat diangkat, akan memunculkan definisi fungsi daripada hanya mengangkat nama fungsi.

Cuplikan kode berikut, menggambarkan pengangkatan fungsi dalam JavaScript.

hoist_function();  
function hoist_function() { 
   console.log("foo"); 
}

Output berikut ditampilkan pada eksekusi yang berhasil dari kode di atas.

foo

Namun, ekspresi fungsi tidak bisa diangkat. Cuplikan kode berikut menggambarkan hal yang sama.

hoist_function(); // TypeError: hoist_function() is not a function  
var hoist_function() = function() { 
   console.log("bar"); 
};

Ekspresi Fungsi yang Segera Dipanggil

Ekspresi Fungsi yang Dipanggil Langsung (IIFE) dapat digunakan untuk menghindari pengangkatan variabel dari dalam blok. Ini memungkinkan akses publik ke metode sambil mempertahankan privasi untuk variabel yang ditentukan dalam fungsi. Pola ini disebut sebagai fungsi anonim yang dijalankan sendiri. Dua contoh berikut menjelaskan konsep ini dengan lebih baik.

Contoh 1: IIFE

var main = function() { 
   var loop = function() { 
      for(var x = 0;x<5;x++) {
         console.log(x); 
      } 
   }(); 
   console.log("x can not be accessed outside the block scope x value is :"+x); 
} 
main();

Contoh 2: IIFE

var main = function() { 
   (function() { 
      for(var x = 0;x<5;x++) { 
         console.log(x); 
      } 
   })(); 
   console.log("x can not be accessed outside the block scope x value is :"+x); 
} 
main();

Kedua Contoh tersebut akan membuat keluaran sebagai berikut.

0 
1 
2 
3 
4 
Uncaught ReferenceError: x is not define

Fungsi Generator

Saat fungsi normal dipanggil, kontrol akan tetap dengan fungsi yang dipanggil hingga kembali. Dengan generator di ES6, fungsi pemanggil sekarang dapat mengontrol pelaksanaan fungsi yang dipanggil. Generator seperti fungsi biasa kecuali itu -

  • Fungsi ini dapat menghasilkan kontrol kembali ke pemanggil kapan saja.

  • Saat Anda memanggil generator, generator tidak langsung bekerja. Sebaliknya, Anda mendapatkan kembali iterator. Fungsi ini berjalan saat Anda memanggil metode iterator selanjutnya.

Generator dilambangkan dengan memberi akhiran pada kata kunci fungsi dengan tanda bintang; jika tidak, sintaksnya identik dengan fungsi biasa.

Contoh berikut menggambarkan hal yang sama.

"use strict" 
function* rainbow() { 
   // the asterisk marks this as a generator 
   yield 'red'; 
   yield 'orange'; 
   yield 'yellow'; 
   yield 'green'; 
   yield 'blue'; 
   yield 'indigo'; 
   yield 'violet'; 
} 
for(let color of rainbow()) { 
   console.log(color); 
}

Generator memungkinkan komunikasi dua arah antara pemanggil dan fungsi yang dipanggil. Ini dilakukan dengan menggunakanyield kata kunci.

Perhatikan contoh berikut -

function* ask() { 
   const name = yield "What is your name?"; 
   const sport = yield "What is your favorite sport?"; 
   return `${name}'s favorite sport is ${sport}`; 
}  
const it = ask(); 
console.log(it.next()); 
console.log(it.next('Ethan'));  
console.log(it.next('Cricket'));

Urutan fungsi generator adalah sebagai berikut -

  • Generator dimulai dalam keadaan jeda; iterator dikembalikan.

  • The it.next () menghasilkan "Siapa nama Anda". Generator dijeda. Ini dilakukan dengan kata kunci hasil.

  • Call it.next ("Ethan") memberikan nilai Ethan ke nama variabel dan menghasilkan "Apa olahraga favorit Anda?" Sekali lagi generator dijeda.

  • Call it.next (“Cricket”) memberikan nilai Cricket ke variabel sport dan mengeksekusi pernyataan return berikutnya.

Oleh karena itu, keluaran dari kode di atas adalah -

{ 
   value: 'What is your name?', done: false 
} 
{ 
   value: 'What is your favorite sport?', done: false 
} 
{ 
   value: 'Ethan\'s favorite sport is Cricket', done: true 
}

Note - Fungsi generator tidak dapat direpresentasikan menggunakan fungsi panah.

Fungsi Panah

Fungsi panah yang diperkenalkan di ES membantu dalam menulis fungsi di JavaScript secara ringkas. Mari kita pelajari hal yang sama secara mendetail.

ES5 dan fungsi Anonim

JavaScript memanfaatkan anonymous functions. Fungsi anonim adalah fungsi yang tidak memiliki nama. Fungsi anonim digunakan selamafunction callback. Contoh berikut menggambarkan penggunaan fungsi anonim di ES5 -

<script>
   setTimeout(function(){
      console.log('Learning at TutorialsPoint is fun!!')
   },1000)
</script>

Contoh di atas meneruskan fungsi anonim sebagai parameter ke pradefinisi setTimeout() function. Fungsi setTimeout () akan memanggil kembali fungsi anonim setelah 1 detik.

Output berikut ditampilkan setelah 1 detik -

Learning at TutorialsPoint is fun!!

Sintaks Fungsi Panah

ES6 memperkenalkan konsep arrow function untuk menyederhanakan penggunaan anonymous function. Ada 3 bagian fungsi panah yaitu sebagai berikut -

  • Parameters - Fungsi panah mungkin memiliki parameter

  • The fat arrow notation (=>) - Ini juga disebut sebagai pergi ke operator

  • Statements - Mewakili set instruksi fungsi

Tip - Berdasarkan konvensi, penggunaan parameter huruf tunggal dianjurkan untuk deklarasi fungsi panah yang kompak dan tepat.

Sintaksis

//Arrow function that points to a single line of code
()=>some_expression

ATAU

//Arrow function that points to a block of code
()=> { //some statements }`

ATAU

//Arrow function with parameters
(param1,param2)=>{//some statement}

Contoh: Fungsi panah di ES6

Contoh berikut mendefinisikan dua ekspresi fungsi add dan isEven menggunakan fungsi panah

<script>
   const add = (n1,n2) => n1+n2
   console.log(add(10,20))

   const isEven = (n1) => {
      if(n1%2 == 0)
         return true;
      else
         return false;
   }
   console.log(isEven(10))
</script>

Output dari kode di atas akan seperti yang disebutkan di bawah ini -

30
true

Array.prototype.map () dan fungsi panah

Dalam contoh berikut, fungsi panah diteruskan sebagai parameter ke Array.prototype.map() function.Fungsi map () menjalankan fungsi panah untuk setiap elemen dalam larik. Fungsi panah dalam kasus ini, menampilkan setiap elemen dalam larik dan indeksnya.

<script>
   const names = ['TutorialsPoint','Mohtashim','Bhargavi','Raja']
   names.map((element,index)=> {
      console.log('inside arrow function')
      console.log('index is '+index+' element value is :'+element)
   })
</script>

Output dari kode di atas akan seperti yang diberikan di bawah ini -

inside arrow function
index is 0 element value is :TutorialsPoint
inside arrow function
index is 1 element value is :Mohtashim
inside arrow function
index is 2 element value is :Bhargavi
inside arrow function
index is 3 element value is :Raja

Contoh: window.setTimeout () dan fungsi panah

Contoh berikut meneruskan fungsi panah sebagai parameter ke standar setTimeout() function. ItusetTimeout() fungsi akan memanggil kembali fungsi panah setelah 1 detik.

<script>
   setTimeout(()=>{
      console.log('Learning at TutorialsPoint is fun!!')
   },1000)
</script>

Output berikut ditampilkan setelah 1 detik -

Learning at TutorialsPoint is fun!!

Fungsi panah dan "ini"

Di dalam fungsi panah jika kita gunakan this pointer, ini akan menunjuk ke lingkup leksikal yang melingkupi. Artinya fungsi panah tidak membuat baruthis pointerMisalnya setiap kali dipanggil. Fungsi panah memanfaatkan ruang lingkup yang melingkupinya. Untuk memahami hal ini, mari kita lihat contohnya.

<script>
   //constructor function
   function Student(rollno,firstName,lastName) {
      this.rollno = rollno;
      this.firstName = firstName;
      this.lastName = lastName;
      this.fullNameUsingAnonymous = function(){
         setTimeout(function(){
            //creates a new instance of this ,hides outer scope of this
            console.log(this.firstName+ " "+this.lastName)
         },2000)
      }
      this.fullNameUsingArrow = function(){
         setTimeout(()=>{
            //uses this instance of outer scope
            console.log(this.firstName+ " "+this.lastName)
         },3000)
      }
   }
   const s1 = new Student(101,'Mohammad','Mohtashim')
   s1.fullNameUsingAnonymous();
   s1.fullNameUsingArrow();
</script>

Saat fungsi anonim digunakan dengan setTimeout(), fungsi tersebut akan dipanggil setelah 2000 milidetik. Contoh baru dari“this”dibuat dan membayangi instance dari fungsi Student. Jadi, nilaithis.firstName dan this.lastName akan undefined. Fungsi tidak menggunakan cakupan leksikal atau konteks eksekusi saat ini. Masalah ini dapat diselesaikan dengan menggunakan filearrow function.

Output dari kode di atas adalah sebagai berikut -

undefined undefined
Mohammad Mohtashim