ES6 - Objek

JavaScript mendukung perluasan tipe data. Objek JavaScript adalah cara terbaik untuk menentukan tipe data kustom.

Sebuah objectadalah sebuah instance yang berisi sekumpulan pasangan nilai kunci. Tidak seperti tipe data primitif, objek dapat mewakili beberapa atau nilai kompleks dan dapat berubah sepanjang waktu hidupnya. Nilainya dapat berupa nilai skalar atau fungsi atau bahkan larik objek lain.

Variasi sintaksis untuk mendefinisikan suatu objek dibahas lebih lanjut.

Penginisialisasi Objek

Seperti tipe primitif, objek memiliki sintaks literal: curly bracesv({dan}). Berikut ini adalah sintaks untuk mendefinisikan suatu objek.

var identifier = {
   Key1:value, Key2: function () { 
      //functions 
   }, 
   Key3: [“content1”,” content2”] 
}

Isi dari suatu objek disebut properties (atau anggota), dan properti terdiri dari a name (atau kunci) dan value. Nama properti harus berupa string atau simbol, dan nilai dapat berupa jenis apa pun (termasuk objek lain).

Seperti semua variabel JavaScript, baik nama objek (yang bisa merupakan variabel normal) dan nama properti peka huruf besar kecil. Anda mengakses properti suatu objek dengan notasi titik sederhana.

Berikut ini adalah sintaks untuk mengakses Properti Objek.

objectName.propertyName

Contoh: Penginisialisasi Objek

var person = { 
   firstname:"Tom", 
   lastname:"Hanks", 
   func:function(){return "Hello!!"},    
}; 
//access the object values 
console.log(person.firstname)   
console.log(person.lastname) 
console.log(person.func())

Contoh di atas, mendefinisikan orang objek. Objek tersebut memiliki tiga properti. Properti ketiga mengacu pada suatu fungsi.

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

Tom 
Hanks 
Hello!!

Di ES6, dengan menetapkan nilai properti yang cocok dengan nama properti, Anda bisa menghilangkan nilai properti.

Contoh

var foo = 'bar' 
var baz = { foo } 
console.log(baz.foo)

Potongan kode di atas mendefinisikan sebuah objek baz. Benda tersebut memiliki propertifoo. Nilai properti dihilangkan di sini karena ES6 secara implisit menetapkan nilai variabel foo ke kunci objek foo.

Berikut ini adalah ES5 yang setara dengan kode di atas.

var foo = 'bar' 
var baz = { foo:foo } 
console.log(baz.foo)

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

bar

Dengan sintaks singkat ini, mesin JS mencari di lingkup berisi untuk variabel dengan nama yang sama. Jika ditemukan, nilai variabel tersebut ditetapkan ke properti. Jika tidak ditemukan, Kesalahan Referensi dilempar.

The Object () Constructor

JavaScript menyediakan fungsi konstruktor khusus yang disebut Object()untuk membangun objek. Operator baru digunakan untuk membuat instance dari suatu objek. Untuk membuat objek, operator baru diikuti dengan metode konstruktor.

Berikut ini adalah sintaks untuk mendefinisikan suatu objek.

var obj_name = new Object(); 
obj_name.property = value;    
OR             
obj_name["key"] = value

Berikut adalah sintaks untuk mengakses properti.

Object_name.property_key                    
OR              
Object_name["property_key"]

Contoh

var myCar = new Object(); 
myCar.make = "Ford"; //define an object 
myCar.model = "Mustang"; 
myCar.year = 1987;  

console.log(myCar["make"]) //access the object property 
console.log(myCar["model"]) 
console.log(myCar["year"])

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

Ford 
Mustang 
1987

Properti objek yang belum ditetapkan tidak ditentukan.

Contoh

var myCar = new Object(); 
myCar.make = "Ford"; 
console.log(myCar["model"])

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

undefined

Note- Nama properti objek dapat berupa string JavaScript yang valid, atau apa pun yang dapat diubah menjadi string, termasuk string kosong. Namun, nama properti apa pun yang bukan pengenal JavaScript yang valid (misalnya, nama properti yang memiliki spasi atau tanda hubung, atau yang dimulai dengan angka) hanya dapat diakses menggunakan notasi kurung siku.

Properti juga dapat diakses dengan menggunakan nilai string yang disimpan dalam variabel. Dengan kata lain, kunci properti objek bisa berupa nilai dinamis. Misalnya: variabel. Konsep tersebut diilustrasikan dalam contoh berikut.

Contoh

var myCar = new Object()  
var propertyName = "make"; 
myCar[propertyName] = "Ford"; 
console.log(myCar.make)

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

Ford

Fungsi Pembuat

Objek dapat dibuat menggunakan dua langkah berikut -

Step 1 - Tentukan tipe objek dengan menulis fungsi konstruktor.

Berikut ini adalah sintaks yang sama.

function function_name() { 
   this.property_name = value 
}

Itu ‘this’ kata kunci mengacu pada objek saat ini yang digunakan dan mendefinisikan properti objek.

Step 2 - Buat instance objek dengan sintaks baru.

var Object_name= new function_name() 
//Access the property value  

Object_name.property_name

Kata kunci baru memanggil konstruktor fungsi dan menginisialisasi kunci properti fungsi.

Example − Using a Function Constructor

function Car() { 
   this.make = "Ford" 
   this.model = "F123" 
}  
var obj = new Car() 
console.log(obj.make) 
console.log(obj.model)

Contoh di atas menggunakan konstruktor fungsi untuk mendefinisikan sebuah objek.

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

Ford 
F123

Properti baru selalu dapat ditambahkan ke objek yang ditentukan sebelumnya. Misalnya, pertimbangkan cuplikan kode berikut -

function Car() { 
   this.make = "Ford" 
} 
var obj = new Car() 
obj.model = "F123" 
console.log(obj.make) 
console.log(obj.model)

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

Ford 
F123

Metode Object.create

Objek juga dapat dibuat menggunakan Object.create()metode. Ini memungkinkan Anda membuat prototipe untuk objek yang Anda inginkan, tanpa harus mendefinisikan fungsi konstruktor.

Contoh

var roles = { 
   type: "Admin", // Default value of properties 
   displayType : function() {  
      // Method which will display type of role 
      console.log(this.type); 
   } 
}  
// Create new role type called super_role 
var super_role = Object.create(roles); 
super_role.displayType(); // Output:Admin  

// Create new role type called Guest 
var guest_role = Object.create(roles); 
guest_role.type = "Guest"; 
guest_role.displayType(); // Output:Guest

Contoh di atas mendefinisikan objek -roles dan menetapkan nilai default untuk properti. Dua contoh baru dibuat yang menggantikan nilai properti default untuk objek.

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

Admin 
Guest

Fungsi Object.assign ()

Itu Object.assign()metode digunakan untuk menyalin nilai dari semua properti enumerable sendiri dari satu atau lebih objek sumber ke objek target. Ini akan mengembalikan objek target.

Berikut ini adalah sintaks yang sama.

Object.assign(target, ...sources)

Example − Cloning an Object

"use strict" 
var det = { name:"Tom", ID:"E1001" }; 
var copy = Object.assign({}, det); 
console.log(copy);  
for (let val in copy) { 
   console.log(copy[val]) 
}

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

Tom 
E1001

Example − Merging Objects

var o1 = { a: 10 }; 
var o2 = { b: 20 }; 
var o3 = { c: 30 }; 
var obj = Object.assign(o1, o2, o3); 
console.log(obj);  
console.log(o1);

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

{ a: 10, b: 20, c: 30 } 
{ a: 10, b: 20, c: 30 }

Note- Tidak seperti menyalin objek, saat objek digabungkan, objek yang lebih besar tidak mempertahankan salinan properti yang baru. Melainkan memegang referensi ke properti yang terkandung dalam objek asli. Contoh berikut menjelaskan konsep ini.

var o1 = { a: 10 }; 
var obj = Object.assign(o1); 
obj.a++ 
console.log("Value of 'a' in the Merged object after increment  ") 
console.log(obj.a);  
console.log("value of 'a' in the Original Object after increment ") 
console.log(o1.a);

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

Value of 'a' in the Merged object after increment 
11  
value of 'a' in the Original Object after increment 
11

Menghapus Properti

Anda dapat menghapus properti dengan menggunakan operator hapus. Kode berikut menunjukkan cara menghapus properti.

Contoh

// Creates a new object, myobj, with two properties, a and b. 
var myobj = new Object; 
myobj.a = 5; 
myobj.b = 12; 

// Removes the ‘a’ property 
delete myobj.a; 
console.log ("a" in myobj) // yields "false"

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

false

Potongan kode menghapus properti dari objek. Contoh mencetak false karena operator in tidak menemukan properti di objek.

Membandingkan Objek

Dalam JavaScript, objek adalah tipe referensi. Dua objek berbeda tidak pernah sama, meskipun mereka memiliki properti yang sama. Ini karena, mereka menunjuk ke alamat memori yang sama sekali berbeda. Hanya objek yang memiliki referensi yang sama yang menghasilkan true pada perbandingan.

Example 1 − Different Object References

var val1 = {name: "Tom"}; 
var val2 = {name: "Tom"}; 
console.log(val1 == val2)  // return false 
console.log(val1 === val2)  // return false

Dalam contoh di atas, val1 dan val2adalah dua objek berbeda yang merujuk ke dua alamat memori yang berbeda. Oleh karena itu, pada perbandingan persamaan, operator akan mengembalikan nilai salah.

Example 2 − Single Object Reference

var val1 = {name: "Tom"}; 
var val2 = val1  

console.log(val1 == val2) // return true 
console.log(val1 === val2) // return true

Dalam contoh di atas, konten dalam val1 ditetapkan ke val2, yaitu referensi properti dalam val1 digunakan bersama dengan val2. Karena, objek sekarang berbagi referensi ke properti, operator persamaan akan mengembalikan nilai true untuk dua objek berbeda yang merujuk ke dua alamat memori yang berbeda. Oleh karena itu, pada perbandingan persamaan, operator akan mengembalikan nilai salah.

De-strukturisasi Objek

Syarat destructuringmengacu pada pemecahan struktur suatu entitas. Sintaks tugas penghancuran dalam JavaScript memungkinkan untuk mengekstrak data dari array atau objek ke dalam variabel yang berbeda. Hal yang sama diilustrasikan dalam contoh berikut.

Contoh 1

Saat merusak sebuah objek, nama variabel dan nama properti objek harus cocok.

<script>
let student = {
   rollno:20,
   name:'Prijin',
   cgpa:7.2
}

//destructuring to same property name
   let {name,cgpa} = student
   console.log(name)
   console.log(cgpa)

//destructuring to different name
   let {name:student_name,cgpa:student_cgpa}=student
   console.log(student_cgpa)
   console.log("student_name",student_name)
</script>

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

Prijin
7.2
7.2
student_name Prijin

Contoh 2

Jika variabel dan penugasan berada dalam dua langkah yang berbeda, maka sintaks objek yang merusak akan dikelilingi oleh () seperti yang ditunjukkan pada contoh ({rollno} = student) -

<script>
   let student = {
      rollno:20,
      name:'Prijin',
      cgpa:7.2
   }

   // destructuring to already declared variable
   let rollno;
   ({rollno} = student)
   console.log(rollno)

   // assign default values to variables

   let product ={ id:1001,price:2000} //discount is not product property
   let {id,price,discount=.10} = product
   console.log(id)
   console.log(price)
   console.log(discount)
</script>

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

20
1001
2000
0.1

Contoh 3

Contoh di bawah ini menunjukkan destructuring menggunakan rest operator dan cara menghancurkan objek bersarang.

<script>
   // rest operator with object destructuring
   let customers= {
      c1:101,
      c2:102,
      c3:103
   }

   let {c1,...others} = customers
   console.log(c1)
   console.log(others)

   //nested objects
   let emp = {
      id:101,
      address:{
         city:'Mumbai',
         pin:1234
      }
   }
   let {address} = emp;

   console.log(address)
   let {address:{city,pin}} = emp
   console.log(city)
</script>

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

101
{c2: 102, c3: 103}
{city: "Mumbai", pin: 1234}
Mumbai