ES6 - Variabel

SEBUAH variable, menurut definisi, adalah "ruang bernama dalam memori" yang menyimpan nilai. Dengan kata lain, ini bertindak sebagai wadah untuk nilai-nilai dalam suatu program. Nama variabel disebutidentifiers. Berikut adalah aturan penamaan untuk pengenal -

  • Pengenal tidak boleh menjadi kata kunci.

  • Pengenal dapat berisi huruf dan angka.

  • Pengenal tidak boleh berisi spasi dan karakter khusus, kecuali garis bawah (_) dan tanda dolar ($).

  • Nama variabel tidak boleh dimulai dengan angka.

Ketik Sintaks

Variabel harus dideklarasikan sebelum digunakan. Sintaks ES5 menggunakanvarkata kunci untuk mencapai hal yang sama. Sintaks ES5 untuk mendeklarasikan variabel adalah sebagai berikut.

//Declaration using var keyword 
var  variable_name

ES6 memperkenalkan sintaks deklarasi variabel berikut -

  • Menggunakan let.
  • Menggunakan const.

Variable initializationmengacu pada proses menyimpan nilai dalam variabel. Variabel dapat diinisialisasi baik pada saat deklarasi atau di lain waktu.

Sintaks tipe ES5 tradisional untuk mendeklarasikan dan menginisialisasi variabel adalah sebagai berikut -

//Declaration using var keyword 
var variable_name = value

Contoh: Menggunakan Variabel

var name = "Tom" 
console.log("The value in the variable is: "+name)

Contoh di atas mendeklarasikan variabel dan mencetak nilainya.

Output berikut ditampilkan pada eksekusi yang berhasil.

The value in the variable is Tom

JavaScript dan Pengetikan Dinamis

JavaScript adalah bahasa yang tidak diketik. Ini berarti variabel JavaScript dapat menyimpan nilai dari semua tipe data. Tidak seperti banyak bahasa lain, Anda tidak perlu memberi tahu JavaScript selama deklarasi variabel jenis nilai apa yang akan dipegang variabel. Jenis nilai variabel dapat berubah selama eksekusi program dan JavaScript akan menanganinya secara otomatis. Fitur ini disebut sebagaidynamic typing.

Cakupan Variabel JavaScript

Cakupan variabel adalah wilayah program Anda yang ditentukan. Secara tradisional, JavaScript hanya mendefinisikan dua cakupan-global dan lokal.

  • Global Scope - Variabel dengan cakupan global dapat diakses dari dalam bagian mana pun dari kode JavaScript.

  • Local Scope - Variabel dengan cakupan lokal dapat diakses dari dalam fungsi yang dideklarasikan.

Contoh: Variabel Global vs. Lokal

Contoh berikut mendeklarasikan dua variabel dengan nama num - satu di luar fungsi (lingkup global) dan yang lainnya di dalam fungsi (lingkup lokal).

var num = 10 
function test() { 
   var num = 100 
   console.log("value of num in test() "+num) 
} 
console.log("value of num outside test() "+num) 
test()

Variabel saat dirujuk dalam fungsi menampilkan nilai variabel cakupan lokal. Namun, variabelnyanum ketika diakses di luar fungsi mengembalikan instance yang tercakup secara global.

Output berikut ditampilkan pada eksekusi yang berhasil.

value of num outside test() 10
value of num in test() 100

ES6 mendefinisikan lingkup variabel baru - Lingkup Blok.

Let and Block Scope

Cakupan blok membatasi akses variabel ke blok tempat ia dideklarasikan. Ituvarkata kunci memberikan ruang lingkup fungsi ke variabel. Berbeda dengan kata kunci var, filelet kata kunci memungkinkan skrip untuk membatasi akses ke variabel ke blok terlampir terdekat.

"use strict" 
function test() { 
   var num = 100 
   console.log("value of num in test() "+num) { 
      console.log("Inner Block begins") 
      let num = 200 
      console.log("value of num : "+num)  
   } 
} 
test()

Skrip mendeklarasikan variabel numdalam lingkup lokal suatu fungsi dan mendeklarasikan ulang dalam blok menggunakan kata kunci let. Nilai variabel cakupan lokal dicetak ketika variabel diakses di luar blok dalam, sedangkan variabel cakupan blok dirujuk di dalam blok dalam.

Note - Mode ketat adalah cara untuk ikut serta dalam varian JavaScript yang dibatasi.

Output berikut ditampilkan pada eksekusi yang berhasil.

value of num in test() 100 
Inner Block begins 
value of num : 200

Contoh: misalkan v / s var

var no = 10; 
var no = 20; 
console.log(no);

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

20

Mari kita tulis ulang kode yang sama menggunakan let kata kunci.

let no = 10; 
let no = 20; 
console.log(no);

Kode di atas akan memunculkan kesalahan: Identifier 'no' telah dideklarasikan. Variabel apa pun yang dideklarasikan menggunakan kata kunci let diberi ruang lingkup blok.

biarkan dan blokir keamanan level

Jika kami mencoba mendeklarasikan a letvariabel dua kali dalam blok yang sama, itu akan melempar kesalahan. Perhatikan contoh berikut -

<script>
   let balance = 5000 // number type
   console.log(typeof balance)
   let balance = {message:"hello"} // changing number to object type
   console.log(typeof balance)
</script>

Kode di atas akan menghasilkan kesalahan berikut -

Uncaught SyntaxError: Identifier 'balance' has already been declared

biarkan dan beberapa blok

Namun, sama saja let variabel dapat digunakan dalam cakupan level blok yang berbeda tanpa kesalahan sintaks.

Contoh

<script>
   let count = 100
   for (let count = 1;count <= 10;count++){
      //inside for loop brackets ,count value starts from 1
      console.log("count value inside loop is ",count);
   }
   //outside for loop brackets ,count value is 100
   console.log("count value after loop is",count);

   if(count == 100){
      //inside if brackets ,count value is 50
      let count = 50;
      console.log("count inside if block",count);
   }
   console.log(count);
</script>

Output dari kode di atas adalah sebagai berikut -

count value inside loop is 1
count value inside loop is 2
count value inside loop is 3
count value inside loop is 4
count value inside loop is 5
count value inside loop is 6
count value inside loop is 7
count value inside loop is 8
count value inside loop is 9
count value inside loop is 10
count value after loop is 100
count inside if block 50
100

Const

Itu constdeklarasi membuat referensi hanya-baca ke suatu nilai. Ini tidak berarti nilai yang dimilikinya tidak dapat diubah, hanya saja pengidentifikasi variabel tidak dapat ditetapkan kembali. Konstanta memiliki cakupan blok, seperti variabel yang ditentukan menggunakan pernyataan let. Nilai konstanta tidak dapat diubah melalui penugasan ulang, dan tidak dapat dideklarasikan kembali.

Aturan berikut berlaku untuk variabel yang dideklarasikan menggunakan const kata kunci -

  • Konstanta tidak dapat ditetapkan ulang nilainya.
  • Konstanta tidak dapat dideklarasikan kembali.
  • Konstanta membutuhkan penginisialisasi. Ini berarti konstanta harus diinisialisasi selama deklarasinya.
  • Nilai yang diberikan ke a const variabel bisa berubah.

Contoh

const x = 10
x = 12 // will result in an error!!

Kode di atas akan mengembalikan kesalahan karena konstanta tidak dapat ditetapkan ulang nilainya. Variabel konstanta tidak dapat diubah.

Konstanta Tidak Berubah

Tidak seperti variabel yang dideklarasikan menggunakan let kata kunci, constantstidak dapat diubah. Artinya nilainya tidak bisa diubah. Misalnya, jika kami mencoba mengubah nilai variabel konstan, kesalahan akan ditampilkan.

<script>
   let income = 100000
   const INTEREST_RATE = 0.08
   income += 50000 // mutable
   console.log("changed income value is ",income)
   INTEREST_RATE += 0.01
   console.log("changed rate is ",INTEREST_RATE) //Error: not mutable
</script>

Output dari kode di atas adalah sebagai berikut -

changed income value is 150000
Uncaught TypeError: Assignment to constant variable

const dan array

Contoh berikut menunjukkan cara membuat array yang tidak dapat diubah. Elemen baru dapat ditambahkan ke array. Namun, menginisialisasi ulang array akan menghasilkan kesalahan seperti yang ditunjukkan di bawah ini -

<script>
   const DEPT_NOS = [10,20,30,50]
   DEPT_NOS.push(40)
   console.log('dept numbers is ',DEPT_NOS)

   const EMP_IDS = [1001,1002,1003]
   console.log('employee ids',EMP_IDS)
   //re assigning variable employee ids
   EMP_IDS = [2001,2002,2003]
   console.log('employee ids after changing',EMP_IDS)
</script>

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

dept numbers is (5) [10, 20, 30, 50, 40]
employee ids (3) [1001, 1002, 1003]
Uncaught TypeError: Assignment to constant variable.

Kata kunci var

Sebelum ES6, file varkata kunci digunakan untuk mendeklarasikan variabel dalam JavaScript. Variabel dideklarasikan menggunakanvartidak mendukung cakupan level blok. Ini berarti jika variabel dideklarasikan dalam satu lingkaran atauif block itu dapat diakses di luar loop atau if block. Ini karena variabel dideklarasikan menggunakanvar dukungan kata kunci mengangkat.

var dan hoisting

Variable hoistingmemungkinkan penggunaan variabel dalam program JavaScript, bahkan sebelum dideklarasikan. Variabel seperti itu akan diinisialisasiundefinedsecara default. Runtime JavaScript akan memindai deklarasi variabel dan meletakkannya di bagian atas fungsi atau skrip. Variabel dideklarasikan denganvarkata kunci diangkat ke atas. Perhatikan contoh berikut -

<script>
   variable company is hoisted to top , var company = undefined
   console.log(company); // using variable before declaring
   var company = "TutorialsPoint"; // declare and initialized here
   console.log(company);
</script>

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

undefined
TutorialsPoint

var dan lingkup blok

Itu block scopemembatasi akses variabel ke blok di mana ia dideklarasikan. Ituvarkata kunci memberikan ruang lingkup fungsi ke variabel. Variabel dideklarasikan menggunakanvarkata kunci tidak memiliki cakupan blok. Perhatikan contoh berikut -

<script>
   //hoisted to top ; var i = undefined
   for (var i = 1;i <= 5;i++){
      console.log(i);
   }
   console.log("after the loop i value is "+i);
</script>

Output dari kode di atas adalah sebagai berikut -

1
2
3
4
5
after the loop i value is 6

Variabel i dideklarasikan di dalam loop for menggunakan varkata kunci. Variabel i dapat diakses di luar loop. Namun, terkadang, mungkin ada kebutuhan untuk membatasi akses variabel di dalam blok. Kami tidak dapat menggunakanvarkata kunci dalam skenario ini. ES6 memperkenalkanlet kata kunci untuk mengatasi batasan ini.

var dan keamanan tingkat blok

Jika kami menyatakan hal yang sama variable dua kali menggunakan var keyworddalam sebuah blok, kompilator tidak akan membuat kesalahan. Namun, hal ini dapat menyebabkan kesalahan logika yang tidak terduga pada waktu proses.

<script>
   var balance = 5000
   console.log(typeof balance)
   var balance = {message:"hello"}
   console.log(typeof balance)
</script>

Output dari kode di atas adalah seperti yang ditunjukkan di bawah ini -

number
object