Destructuring Array dan Object di JavaScript

Created at by Aris Munandar

Jika kamu sudah mulai belajar JavaScript modern (ES6 ke atas), kamu pasti menyadari bahwa gaya penulisan kode JavaScript saat ini jauh lebih ringkas, rapi, dan mudah dibaca dibandingkan era sebelumnya. Salah satu fitur yang membuat hal itu terjadi adalah destructuring — sebuah teknik yang memungkinkan kita mengambil nilai dari array atau object dengan cara yang lebih elegan. Fitur ini bukan hanya mempercepat proses penulisan kode, tetapi juga membuat struktur program lebih mudah dipahami, terutama saat menangani data yang kompleks.

Dalam dunia development modern, kita sangat sering bekerja dengan API response, konfigurasi, data user, hingga daftar produk dalam bentuk array atau object. Tanpa destructuring, kode yang kita tulis akan panjang, penuh repetisi, dan tidak efisien. Itulah mengapa memahami destructuring array JavaScript dan destructuring object JavaScript menjadi skill wajib bagi developer masa kini—baik pemula maupun yang sudah berpengalaman.

Pada artikel panjang ini, kita akan membahas destructuring secara mendalam, dimulai dari dasar hingga level yang lebih lanjut, termasuk:

  • Cara kerja destructuring di JavaScript ES6
  • Contoh penggunaan pada array dan object
  • Nested destructuring
  • Default value
  • Rest operator
  • Destructuring di parameter function
  • Hingga best practice dalam proyek modern

Pembahasan akan dibuat langkah demi langkah, dengan contoh kode yang menggunakan indentasi 4 spasi agar mudah dibaca. Harapannya, setelah selesai membaca artikel ini, kamu tidak hanya sekadar memahami syntax, tetapi juga benar-benar mahir mengimplementasikannya dalam berbagai situasi nyata di proyek JavaScript modern.

Baca juga: Tutorial Arrow Function di JavaScript

Apa Itu Destructuring di JavaScript?

Destructuring adalah fitur baru yang diperkenalkan sejak ES6 (ECMAScript 2015) yang memungkinkan kita mengambil nilai dari array atau object dan menyimpannya ke dalam variabel dengan cara yang lebih singkat, jelas, dan terstruktur. Dengan destructuring, kamu tidak perlu lagi menulis kode panjang hanya untuk mengambil nilai tertentu dari sebuah data kompleks.

Secara sederhana:

Destructuring = membongkar struktur data (array atau object) menjadi variabel-variabel kecil.

Fitur ini sangat berguna karena JavaScript modern banyak berinteraksi dengan data bertipe objek dan array, terutama saat mengolah:

  • Response API
  • Parameter function
  • Konfigurasi (settings)
  • Data user
  • Manipulasi list atau tabel data
  • Hingga proses pemetaan nilai menggunakan array method seperti map, filter, dan reduce

Tujuan Destructuring

Sebelum ES6, jika ingin mengambil beberapa nilai dari array atau object, kita harus menuliskannya seperti ini:

const user = {
    name: "Aris",
    age: 28,
    country: "Indonesia"
};

const name = user.name;
const age = user.age;
const country = user.country;Code language: JavaScript (javascript)

Dengan destructuring, kode yang sama bisa ditulis jauh lebih ringkas:

const { name, age, country } = user;Code language: JavaScript (javascript)

Satu baris sudah cukup, lebih bersih, dan mudah dibaca.

Bagaimana Destructuring Bekerja?

Destructuring bekerja berdasarkan struktur data:

  • Array destructuring berdasarkan posisi (index).
  • Object destructuring berdasarkan nama key (property).

Sebagai contoh:

Array Destructuring

const colors = ["red", "green", "blue"];
const [first, second, third] = colors;Code language: JavaScript (javascript)

Object Destructuring

const person = { name: "Lisa", age: 30 };
const { name, age } = person;Code language: JavaScript (javascript)

Dengan cara ini, proses pengambilan data menjadi jauh lebih intuitif dan tidak repetitif.

Kenapa Destructuring Penting dalam JavaScript Modern

Ada beberapa alasan utama kenapa destructuring menjadi fitur wajib dikuasai:

  1. Membuat Kode Lebih Singkat
    Tanpa destructuring, kode cenderung lebih panjang dan penuh duplikasi nama variabel.

  2. Lebih Mudah Dibaca
    Struktur pengambilan data menjadi lebih jelas dan terprediksi.

  3. Cocok untuk Data Kompleks
    Banyak API modern mengembalikan data kompleks berupa objek bersarang (nested object). Destructuring sangat membantu membongkar data tersebut.

  4. Dipakai di Banyak Tempat
    Mulai dari Vue, React, Node.js, Express, Next.js, hingga TypeScript — semuanya memanfaatkan destructuring secara intensif.

Contoh Sederhana Perbandingan Sebelum dan Sesudah Destructuring

Tanpa Destructuring

const data = {
    title: "Belajar JavaScript",
    author: "Aris",
    year: 2025
};

const title = data.title;
const author = data.author;
const year = data.year;Code language: JavaScript (javascript)

Dengan Destructuring

const { title, author, year } = data;Code language: JavaScript (javascript)

Perbedaannya jelas — lebih efisien, lebih teratur, dan lebih sesuai dengan gaya JavaScript modern.

Dasar Destructuring Array

Destructuring array adalah teknik untuk mengambil nilai dari sebuah array berdasarkan urutan index dan menyimpannya ke variabel dengan cara yang lebih ringkas dan mudah dibaca. Konsep ini sangat membantu ketika kamu bekerja dengan data yang disusun dalam bentuk list, hasil API, atau kumpulan nilai tertentu.

Pada dasarnya, destructuring array mengikuti posisi (bukan nama) sehingga penting untuk memahami urutan item di dalam array.

Cara Dasar Destructuring Array

Sebelum ES6, jika ingin mengambil beberapa nilai dari sebuah array, kita harus menuliskannya seperti ini:

const fruits = ["apel", "mangga", "jeruk"];

const first = fruits[0];
const second = fruits[1];
const third = fruits[2];Code language: JavaScript (javascript)

Dengan destructuring:

const [first, second, third] = fruits;Code language: JavaScript (javascript)

Hanya satu baris dan semua nilai langsung tertangkap ke variabel sesuai urutannya.

Melewati (Skipping) Nilai dalam Array

Destructuring tidak mengharuskan kita mengambil semua nilai. Kamu bisa melewati (skip) nilai tertentu dengan membiarkan posisi tersebut kosong.

Contoh:

const numbers = [10, 20, 30, 40];

const [first, , third] = numbers;Code language: JavaScript (javascript)

Penjelasan:

  • first = 10
  • posisi index ke-1 dilewati
  • third = 30

Teknik ini sangat berguna saat hanya membutuhkan sebagian data saja.

Mengatur Default Value

Kadang array tidak selalu berisi data lengkap. Agar variabel tetap mendapatkan nilai, kita bisa memberikan default value.

Contoh:

const users = ["Aris"];

const [name, age = 25] = users;Code language: JavaScript (javascript)

Karena hanya ada satu elemen:

  • name = "Aris"
  • age tidak ada → otomatis menggunakan default 25.

Default value ini sangat bermanfaat untuk mencegah error atau nilai undefined.

Menangkap Sisa Nilai dengan Rest Operator

Rest operator (...) digunakan untuk mengumpulkan sisa nilai array ke dalam satu variabel baru.

Contoh:

const colors = ["red", "green", "blue", "yellow"];

const [primary1, primary2, ...others] = colors;Code language: JavaScript (javascript)

Hasil:

  • primary1 = "red"
  • primary2 = "green"
  • others = ["blue", "yellow"]

Ini sangat berguna ketika:

  • ingin mengambil nilai tertentu di awal
  • sisanya ingin diolah kemudian

Destructuring Nested Array (Array Bersarang)

Array bisa memiliki struktur bersarang, dan destructuring tetap dapat dilakukan dengan pola yang sama.

Contoh:

const points = [10, 20, [30, 40]];

const [x, y, [z, w]] = points;Code language: JavaScript (javascript)

Hasil:

  • x = 10
  • y = 20
  • z = 30
  • w = 40

Nested destructuring sangat membantu saat bekerja dengan data seperti:

  • koordinat
  • matriks
  • API respons berbentuk array dalam array

Contoh Real Case: Mengambil Data Respons API

Misalkan API mengembalikan data bentuk array seperti:

const response = ["success", 200, ["Aris", "Budi", "Santi"]];

const [status, code, users] = response;Code language: JavaScript (javascript)

Atau langsung nested:

const [status, code, [u1, u2, u3]] = response;Code language: JavaScript (javascript)

Dengan destructuring, kamu bisa mengambil nilai secara cepat tanpa harus menulis akses index berkali-kali.

Error Umum pada Destructuring Array

Beberapa kesalahan yang sering terjadi:

1. Mengambil index dari array kosong

const [] = [];Code language: JavaScript (javascript)

Tidak error, tetapi semua variabel akan undefined.

2. Mengambil lebih banyak variabel dari jumlah elemennya

const [a, b, c] = [1];Code language: JavaScript (javascript)

Hasil:

  • a = 1
  • b = undefined
  • c = undefined

3. Salah paham tentang posisi

Karena destructuring array berbasis posisi, maka urutannya harus benar.

Bagian ini memberikan dasar kuat untuk memahami konsep destructuring array sebelum lanjut ke fitur lebih kompleks.

Dasar Destructuring Object

Jika destructuring array mengambil nilai berdasarkan urutan, maka destructuring object bekerja berdasarkan nama properti. Ini berarti selama nama variabel cocok dengan nama key dalam object, maka nilai akan tersimpan dengan benar — terlepas dari urutan propertinya.

Destructuring object merupakan fitur ES6 yang sangat penting untuk menulis kode JavaScript yang lebih bersih, rapi, dan mudah dikelola, khususnya ketika bekerja dengan data API, konfigurasi aplikasi, atau object yang kompleks.

Cara Dasar Destructuring Object

Sebelum ES6, mengambil nilai dari object biasanya seperti ini:

const user = {
    name: "Aris",
    age: 25,
    job: "Developer"
};

const name = user.name;
const age = user.age;
const job = user.job;Code language: JavaScript (javascript)

Dengan destructuring:

const { name, age, job } = user;Code language: JavaScript (javascript)

Lebih singkat, mudah dibaca, dan tidak repetitif.

Mengganti Nama Variabel dengan Alias

Kadang kita ingin menggunakan nama variabel yang berbeda dari nama property. Caranya menggunakan sintaks property: alias.

Contoh:

const product = {
    id: 101,
    title: "Keyboard Mechanical"
};

const { id: productId, title: productName } = product;Code language: JavaScript (javascript)

Hasil:

  • productId = 101
  • productName = "Keyboard Mechanical"

Alias sangat berguna dalam situasi:

  • menghindari nama variabel bentrok
  • membuat nama lebih deskriptif
  • merapikan struktur variabel

Memberikan Default Value

Seperti pada destructuring array, kita dapat memberikan default value untuk mencegah hasil undefined.

Contoh:

const settings = {
    theme: "dark"
};

const { theme, fontSize = 14 } = settings;Code language: JavaScript (javascript)

Hasil:

  • theme = "dark"
  • fontSize = 14 (karena tidak ada di object)

Default value ideal digunakan untuk:

  • data konfigurasi
  • object dari API yang tidak lengkap
  • keamanan nilai fallback

Destructuring Object Bersarang (Nested Object)

Saat bekerja dengan data API, object bersarang adalah hal umum. Destructuring dapat dilakukan secara bertingkat.

Contoh:

const user = {
    name: "Aris",
    address: {
        city: "Jakarta",
        zip: 12345
    }
};

const { name, address: { city, zip } } = user;Code language: JavaScript (javascript)

Hasil:

  • name = "Aris"
  • city = "Jakarta"
  • zip = 12345

Catatan penting:

address tidak ikut dibuat sebagai variabel, karena kita langsung mengambil city dan zip.

Menangkap Sisa Properti dengan Rest Operator

Rest operator (…) juga dapat digunakan pada object.

Contoh:

const user = {
    name: "Aris",
    age: 25,
    job: "Developer",
    country: "Indonesia"
};

const { name, age, ...others } = user;Code language: JavaScript (javascript)

Hasil:

  • name = "Aris"
  • age = 25
  • others = { job: "Developer", country: "Indonesia" }

Ini sangat berguna saat:

  • mengambil properti tertentu saja
  • ingin memisahkan object besar menjadi bagian kecil
  • membuat fungsi yang fleksibel dalam menangani argumen object

Mengambil Properti dengan Nama Berbeda dari Variabel yang Sama (Shorthand)

Jika nama variabel sama dengan nama property, cukup tulis sekali saja.

Contoh:

const config = {
    port: 3000,
    host: "localhost"
};

const { port, host } = config;Code language: JavaScript (javascript)

Shorthand ini membuat kode lebih bersih dan efisien.

Contoh Real Case Penggunaan Destructuring Object

1. Respons API

const response = {
    status: "success",
    code: 200,
    data: {
        username: "arisdev",
        email: "aris@example.com"
    }
};

const {
    status,
    code,
    data: { username, email }
} = response;Code language: JavaScript (javascript)

2. Parameter Function

function createUser({ name, age, job }) {
    console.log(name, age, job);
}

createUser({ name: "Aris", age: 25, job: "Developer" });Code language: JavaScript (javascript)

3. Pengambilan konfigurasi

const { mode = "production", debug = false } = options;Code language: JavaScript (javascript)

Error Umum pada Destructuring Object

1. Object kosong

const { a } = {};Code language: JavaScript (javascript)

→ hasil a = undefined.

2. Property tidak ada

const { age } = { name: "Aris" };Code language: JavaScript (javascript)

→ age = undefined (kecuali diberi default value).

3. Nested destructuring tanpa memastikan object-nya ada

const { profile: { email } } = user; // bisa error jika profile undefinedCode language: JavaScript (javascript)

Solusi:

Gunakan optional chaining:

const email = user.profile?.email;Code language: JavaScript (javascript)

Nested Destructuring

Nested destructuring adalah teknik destructuring tingkat lanjut yang memungkinkan kita mengambil nilai dari struktur data yang bersarang (nested), baik berupa array di dalam object, object di dalam array, atau kombinasi keduanya.

Fitur ini sangat berguna saat bekerja dengan data kompleks seperti respons API, data user, konfigurasi aplikasi, hingga struktur dataset yang memiliki banyak tingkatan.

Nested destructuring membantu kita menghindari penulisan panjang seperti:

const city = user.address.city;
const zip = user.address.zip;Code language: JavaScript (javascript)

Dengan destructuring bersarang, ini dapat diringkas menjadi:

const { address: { city, zip } } = user;Code language: JavaScript (javascript)

Bagian ini akan membahas penggunaan nested destructuring untuk berbagai skenario.

Nested Destructuring pada Object Bersarang

Skenario paling sering adalah object di dalam object.

Contoh dasar:

const user = {
    name: "Aris",
    contact: {
        email: "aris@example.com",
        phone: "081234567890"
        }
    };

    const { 
        name,
        contact: { email, phone }
    } = user;Code language: JavaScript (javascript)

Hasil:

  • name = "Aris"
  • email = "aris@example.com"
  • phone = "081234567890"

Perhatikan bahwa variabel contact tidak dibuat, kecuali ditulis secara eksplisit.

Nested Destructuring pada Array Bersarang

Array juga dapat berisi array di dalamnya.

Contoh dasar:

const colors = ["red", ["green", "lightgreen"], "blue"];

const [primary, [secondary, light], tertiary] = colors;Code language: JavaScript (javascript)

Hasil:

  • primary = "red"
  • secondary = "green"
  • light = "lightgreen"
  • tertiary = "blue"

Nested destructuring array memudahkan pengambilan elemen tertentu tanpa harus melakukan akses berulang seperti colors[1][0].

Nested Destructuring pada Array of Object

Ini adalah bentuk yang sangat sering ditemui, terutama saat mengambil data API.

Contoh:

const products = [
    {
        id: 1,
        name: "Keyboard",
        price: 350000
    },
    {
        id: 2,
        name: "Mouse",
        price: 150000
    }
];

const [
    { name: firstProduct },
    { name: secondProduct }
] = products;Code language: JavaScript (javascript)

Hasil:

  • firstProduct = "Keyboard"
  • secondProduct = "Mouse"

Nested Destructuring pada Object of Array

Object juga bisa berisi array sebagai property.

Contoh:

const profile = {
    username: "arisdev",
    hobbies: ["coding", "gaming", "fishing"]
};

const { 
    username,
    hobbies: [hobby1, hobby2, hobby3]
} = profile;Code language: JavaScript (javascript)

Hasil:

  • username = "arisdev"
  • hobby1 = "coding"
  • hobby2 = "gaming"
  • hobby3 = "fishing"

Nested Destructuring dengan Default Value

Saat nilai bersarang tidak pasti ada, memberikan default value sangat membantu agar tidak terjadi error.

Contoh:

const response = {
    status: "success",
    data: {
        user: {
            name: "Aris"
            }
        }
};

const {
    data: {
        user: {
            name,
            email = "email@default.com"
            }
        }
    } = response;Code language: JavaScript (javascript)

Hasil:

  • name = "Aris"
  • email = "email@default.com"

Nested Destructuring dengan Alias

Anda juga dapat memberikan alias saat melakukan nested destructuring.

Contoh:

const company = {
    name: "Tech Corp",
    address: {
        city: "Jakarta",
        street: "Sudirman"
        }
    };

const {
    name: companyName,
    address: { city: companyCity, street: companyStreet }
} = company;Code language: JavaScript (javascript)

Hasil:

  • companyName = "Tech Corp"
  • companyCity = "Jakarta"
  • companyStreet = "Sudirman"

Alias sangat berguna untuk:

  • Memperjelas konteks
  • Menghindari nama variabel konflik
  • Membuat kode lebih mudah dipahami dalam data bersarang

Nested Destructuring + Rest Operator

Kita dapat menggabungkan nested destructuring dengan rest operator (…) untuk menangkap sisa data.

Contoh:

const user = {
    name: "Aris",
    address: {
        city: "Bandung",
        country: "Indonesia",
        postal: 40123
    }
};

const {
    address: { city, ...otherAddress }
} = user;Code language: JavaScript (javascript)

Hasil:

  • city = "Bandung"
  • otherAddress = { country: "Indonesia", postal: 40123 }

Nested Destructuring pada Parameter Function

Nested destructuring bisa langsung dilakukan pada parameter function untuk mempersingkat kode.

Contoh:

function printUser({
    name,
    contact: { email, phone }
}) {
    console.log(name, email, phone);
}

const user = {
    name: "Aris",
    contact: {
        email: "aris@example.com",
        phone: "081200011122"
    }
};

printUser(user);Code language: JavaScript (javascript)

Hasil:

  • Aris aris@example.com 081200011122

Teknik ini sangat populer dalam:

  • React component props
  • Konfigurasi function
  • Data API

Error Umum pada Nested Destructuring

1. Destructuring value yang undefined

const { address: { city } } = user; // error jika user.address undefinedCode language: JavaScript (javascript)

Solusi:

Gunakan optional chaining:

const city = user.address?.city;Code language: JavaScript (javascript)

2. Destructuring array bersarang yang tidak lengkap

const [a, [b, c]] = [1]; // errorCode language: JavaScript (javascript)

Solusi:

Berikan default:

const [a, [b, c] = []] = [1];Code language: JavaScript (javascript)

3. Salah alias penamaan

const { name: namaUser } = user;
console.log(name); // error, karena variabelnya 'namaUser'Code language: JavaScript (javascript)

Solusi:

const { name: namaUser } = user;
console.log(namaUser); // "Aris"Code language: JavaScript (javascript)

Nested destructuring adalah fitur yang sangat kuat, namun juga perlu kehati-hatian karena kesalahan kecil dapat menimbulkan error. Dengan memahami dasarnya, Anda dapat menulis kode yang lebih rapi, modern, dan efisien.

Default Value pada Destructuring

Dalam proses destructuring, kita dapat memberikan nilai default agar variabel tetap memiliki nilai saat data yang diambil ternyata undefined. Fitur ini sangat bermanfaat ketika kita bekerja dengan data eksternal (API), form input, atau variabel opsional.

Default value dapat digunakan pada array destructuring maupun object destructuring. Mari kita bahas satu per satu agar mudah dipahami.

Default Value pada Destructuring Array

Ketika suatu elemen array tidak tersedia, JavaScript akan mengisinya dengan undefined. Dengan default value, kita bisa menentukan nilai pengganti agar variabel tidak kosong.

Contoh tanpa default value:

const colors = ['red'];

const [primary, secondary] = colors;

console.log(primary);    // 'red'
console.log(secondary);  // undefinedCode language: JavaScript (javascript)

Agar secondary tidak undefined, kita bisa memberi nilai default.

Contoh dengan default value:

const colors = ['red'];

const [primary, secondary = 'blue'] = colors;

console.log(primary);    // 'red'
console.log(secondary);  // 'blue'Code language: JavaScript (javascript)

Hal ini sangat membantu jika kita ingin memastikan variabel memiliki nilai yang aman.

Default Value pada Destructuring Object

Pada object, default value digunakan jika property yang diambil tidak ada atau bernilai undefined.

Contoh tanpa default value:

const user = {
    name: 'Aris'
};

const { name, age } = user;

console.log(name);  // 'Aris'
console.log(age);   // undefinedCode language: JavaScript (javascript)

Contoh dengan default value:

const user = {
    name: 'Aris'
};

const { name, age = 25 } = user;

console.log(name);  // 'Aris'
console.log(age);   // 25Code language: JavaScript (javascript)

Default Value + Rename (Alias)

Default value juga bisa digabung dengan rename untuk membuat penulisan variabel lebih fleksibel.

Contoh:

const product = {
    title: 'Headset'
};

const {
    title: productTitle,
    stock: productStock = 10
} = product;

console.log(productTitle); // 'Headset'
console.log(productStock); // 10Code language: JavaScript (javascript)

Ini berguna saat kita bekerja dengan API yang memiliki struktur berbeda. Kita bisa memberi nama variabel sesuai kebutuhan.

Default Value pada Nested Destructuring

Default value juga dapat dipakai di dalam nested destructuring.

Contoh:

const user = {
    name: 'Budi',
    address: {}
};

const {
    address: {
        city = 'Kota Belum Diisi'
    }
} = user;

console.log(city);  // 'Kota Belum Diisi'Code language: JavaScript (javascript)

Tanpa default value, kode di atas bisa menghasilkan error atau nilai undefined.

Default Value pada Parameter Function (Dengan Destructuring)

Destructuring + default value sangat sering digunakan pada parameter function, khususnya untuk konfigurasi dan opsi.

Contoh penerapan:

function createUser({ name = 'Guest', isAdmin = false } = {}) {
    console.log(name, isAdmin);
}

createUser();                    // Guest false
createUser({ name: 'Aris' });    // Aris falseCode language: JavaScript (javascript)

Penjelasan:

Kita memberi default untuk object parameter: {} sehingga jika function dipanggil tanpa argumen, tetap tidak error.

Setiap property juga diberi default value masing-masing.

Ini adalah salah satu contoh best practice modern JavaScript.

Contoh:

createUser({ isAdmin: true });   // Guest trueCode language: JavaScript (javascript)

Penjelasan:

  • Kita memberi default untuk object parameter: {} sehingga jika function dipanggil tanpa argumen, tetap tidak error.
  • Setiap property juga diberi default value masing-masing.

Ini adalah salah satu contoh best practice modern JavaScript.

Kapan Harus Menggunakan Default Value?

Gunakan default value ketika:

  • Data bersifat opsional
  • Data bisa kosong / undefined
  • Ingin membuat fallback value
  • Ingin menulis kode lebih aman dan mudah diprediksi
  • Saat membuat function yang menerima banyak opsi (configuration object)

Kesalahan Umum Default Value pada Destructuring

Mengira default value digunakan ketika nilai null

→ Padahal default value baru aktif jika nilainya undefined, bukan null.

const [value = 'default'] = [null];
console.log(value);  // null (bukan 'default')Code language: JavaScript (javascript)

Lupa memberi default pada parameter object dalam function

→ Akibatnya function error ketika dipanggil tanpa argumen.

function test({ a = 1 }){
    console.log(a);
}

test();  // TypeError: Cannot destructure property 'a' of 'undefined'Code language: JavaScript (javascript)

Solusi aman:

function test({ a = 1 } = {}){
    console.log(a);
}

test();  // 1Code language: JavaScript (javascript)

Rest Operator dalam Destructuring

Rest operator (…) merupakan salah satu fitur ES6 yang sangat berguna ketika bekerja dengan data yang jumlahnya dinamis. Dalam konteks destructuring, rest operator digunakan untuk mengambil sisa elemen dari array atau sisa properti dari object dan menggabungkannya menjadi sebuah variabel baru.

Fitur ini sangat berguna saat kamu ingin memisahkan sebagian data dan tetap menyimpan sisanya tanpa harus menuliskan semuanya satu per satu.

Pada bagian ini, kita akan membahas:

  • Apa itu rest operator?
  • Rest operator pada destructuring array
  • Rest operator pada destructuring object
  • Rest operator vs spread operator
  • Aturan penting rest operator
  • Kesalahan umum pemula
  • Contoh penggunaan praktis

Apa Itu Rest Operator?

Rest operator adalah tanda tiga titik … yang digunakan untuk mengumpulkan sisa elemen menjadi sebuah array atau object baru.

Contoh sederhana:

const [...rest] = [1, 2, 3];
console.log(rest); // [1, 2, 3]Code language: JavaScript (javascript)

Tujuan utamanya adalah untuk mengambil “sisa” data tanpa harus menuliskannya satu per satu.

Rest Operator pada Destructuring Array

Ketika melakukan destructuring pada array, rest operator akan mengambil semua sisa elemen setelah elemen yang ditentukan sebelumnya.

Contoh Penggunaan Dasar

const numbers = [10, 20, 30, 40, 50];

const [first, second, ...others] = numbers;

console.log(first);   // 10
console.log(second);  // 20
console.log(others);  // [30, 40, 50]Code language: JavaScript (javascript)

Di sini:

  • first → elemen pertama
  • second → elemen kedua
  • others → semua elemen setelahnya

Contoh: Mengambil item pertama dari daftar

const fruits = ['apple', 'banana', 'orange'];

const [favorite, ...others] = fruits;

console.log(favorite); // 'apple'
console.log(others);   // ['banana', 'orange']Code language: JavaScript (javascript)

Rest Operator pada Destructuring Object

Rest operator juga dapat digunakan pada object untuk mengambil sisa properti yang tidak disebutkan.

Contoh Penggunaan Dasar

const user = {
    name: 'Aris',
    age: 25,
    country: 'Indonesia',
    job: 'Developer'
};

const { name, ...details } = user;

console.log(name);     // 'Aris'
console.log(details);  // { age: 25, country: 'Indonesia', job: 'Developer' }Code language: JavaScript (javascript)

Penjelasan:

  • name → diambil secara eksplisit
  • details → semua properti lain digabung menjadi object baru

Contoh: Memisahkan properti penting

const config = {
    url: '/api/users',
    method: 'GET',
    headers: { 'Content-Type': 'application/json' }
};

const { url, ...options } = config;

console.log(url);     // '/api/users'
console.log(options); // { method: 'GET', headers: {...} }Code language: JavaScript (javascript)

Rest Operator vs Spread Operator (Beda Fungsi!)

Meskipun sama-sama menggunakan ..., rest operator dan spread operator memiliki fungsi yang berlawanan.

Rest Operator

  • Digunakan saat destructuring
  • Mengumpulkan sisa elemen
  • Output: array atau object baru berisi sisa elemen

Spread Operator

  • Digunakan saat menyebarkan array/object ke tempat lain
  • Menyalin atau menggabungkan data

Contoh perbedaan

Rest: (mengumpulkan)

const [first, ...rest] = [1, 2, 3];
console.log(rest); // [2, 3]Code language: JavaScript (javascript)

Spread: (menyebarkan)

const nums = [1, 2, 3];
const newArr = [...nums, 4];
console.log(newArr); // [1, 2, 3, 4]Code language: JavaScript (javascript)

Aturan Penting Rest Operator

Ada beberapa aturan yang harus kamu perhatikan agar destructuring dengan rest operator tidak error:

1. Rest operator harus berada di posisi terakhir

Array:

const [a, ...rest, b] = [1, 2, 3, 4]; 
// ERROR — rest harus di akhirCode language: JavaScript (javascript)

Object:

const { a, ...rest, b } = obj;
// ERROR — rest harus paling akhirCode language: JavaScript (javascript)

2. Tidak bisa digunakan untuk mengambil elemen tengah secara langsung

Jika ingin mengambil tengah, kamu harus membuat destructuring tambahan.

3. Tidak bisa mengambil properti non-enumerable (misalnya symbol)

Rest operator hanya mengambil properti enumerable biasa.

Kesalahan Umum Pemula

Berikut beberapa kesalahan yang sering terjadi:

  1. Mengira rest dan spread itu sama
    Padahal rest → mengumpulkan, spread → menyebarkan.

  2. Lupa bahwa rest harus berada di akhir
    Baik pada array maupun object.

  3. Menggunakan rest pada nilai primitif
    Rest hanya bekerja pada array dan object.

  4. Mengira rest bisa memfilter properti tertentu otomatis
    Padahal rest hanya mengambil sisa properti yang tidak disebutkan.

Contoh Penggunaan Rest Operator dalam Kasus Nyata

Contoh 1 — Mengambil sisa parameter function

function sum(first, ...numbers) {
    console.log(numbers); // sisa angka
}

sum(1, 2, 3, 4, 5);Code language: JavaScript (javascript)

Output:

[2, 3, 4, 5]Code language: JSON / JSON with Comments (json)

Contoh 2 — Membersihkan object dari key tertentu

const { password, ...safeUser } = {
    username: 'arisdev',
    password: 'rahasia',
    role: 'admin'
};

console.log(safeUser);Code language: JavaScript (javascript)

Output:

{ username: 'arisdev', role: 'admin' }Code language: CSS (css)

Sangat berguna saat ingin menghapus data sensitif.

Rest operator adalah fitur yang sangat penting dalam destructuring karena membuat kita lebih fleksibel saat mengelola data dalam jumlah banyak. Dengan memahami cara kerjanya pada array dan object, kamu bisa menulis kode yang lebih efisien, rapih, dan modern sesuai standar ES6.

Destructuring dalam Parameter Function

Destructuring bukan hanya digunakan untuk mengambil nilai dari array atau object di luar function, tetapi juga bisa diterapkan langsung pada parameter function. Ini adalah salah satu penggunaan destructuring yang paling kuat dalam JavaScript modern, terutama dalam pengembangan aplikasi skala besar.

Pada bagian ini kita akan membahas:

  • Kenapa destructuring di parameter function penting
  • Destructuring pada parameter array
  • Destructuring pada parameter object
  • Menambahkan default value
  • Destructuring pada parameter function bersarang
  • Contoh kasus real-world
  • Best practice

Mari kita masuk ke pembahasannya satu per satu.

Kenapa Destructuring di Parameter Function Penting?

Jika kamu sering membuat function yang menerima object konfigurasi, data user, atau array data, destructuring dapat:

  • membuat function lebih bersih dan mudah dibaca
  • mengurangi repetisi kode
  • mencegah error akibat pemanggilan properti yang dalam
  • memberikan nilai default dengan mudah

Dari gaya penulisan seperti ini:

function createUser(user) {
    console.log(user.name);
    console.log(user.age);
    console.log(user.country);
}Code language: JavaScript (javascript)

Menjadi seperti ini:

function createUser({ name, age, country }) {
    console.log(name);
    console.log(age);
    console.log(country);
}Code language: JavaScript (javascript)

Lebih ringkas, bersih, dan mudah dipahami.

Destructuring pada Parameter Array

Jika function kamu menerima sebuah array, kamu bisa langsung memecahnya menjadi variabel menggunakan array destructuring.

Contoh Dasar

function printCoordinates([x, y]) {
    console.log(`X: ${x}`);
    console.log(`Y: ${y}`);
}

printCoordinates([10, 20]);Code language: JavaScript (javascript)

Output:

X: 10
Y: 20Code language: HTTP (http)

Contoh: Mengambil data user dari array

function showUser([id, name, role]) {
    console.log(id, name, role);
}

showUser([1, 'Aris', 'admin']);Code language: JavaScript (javascript)

Destructuring pada Parameter Object

Inilah penggunaan yang paling umum dan paling membantu dalam development modern.

Contoh Dasar

function displayUser({ name, age }) {
    console.log(`Nama: ${name}`);
    console.log(`Umur: ${age}`);
}

displayUser({
    name: 'Aris',
    age: 25
});Code language: JavaScript (javascript)

Tidak perlu lagi menulis user.name, user.age, dan seterusnya.

Contoh: Parameter Banyak dengan Urutan Tidak Penting

Destructuring pada object tidak bergantung pada urutan!

function connectDB({
    host,
    port,
    username,
    password
}) {
    console.log(host, port, username, password);
}

connectDB({
    port: 3306,
    host: 'localhost',
    password: 'secret',
    username: 'root'
});Code language: JavaScript (javascript)

Menambahkan Default Value di Parameter Function

Default value bisa digunakan untuk memberi nilai fallback jika data tidak tersedia.

Default Value untuk Array

function multiply([a = 1, b = 1]) {
    return a * b;
}

console.log(multiply([5])); // 5 * 1 = 5Code language: JavaScript (javascript)

Default Value untuk Object

function greet({ name = 'Guest', message = 'Welcome' }) {
    console.log(`${message}, ${name}!`);
}

greet({ name: 'Aris' });Code language: JavaScript (javascript)

Output:

Welcome, Aris!

Nested Destructuring di Parameter Function

Jika data yang masuk memiliki struktur bersarang, destructuring bisa langsung mengambil data dalam.

Contoh: Object di Dalam Object

function showProfile({
    username,
    address: { city, country }
}) {
    console.log(username);
    console.log(city, country);
}

showProfile({
    username: 'arisdev',
    address: {
        city: 'Bandung',
        country: 'Indonesia'
    }
});Code language: JavaScript (javascript)

Contoh: Array di Dalam Object

function processOrder({
    id,
    items: [firstItem, ...others]
}) {
    console.log('Order ID:', id);
    console.log('Item pertama:', firstItem);
    console.log('Item lainnya:', others);
}

processOrder({
    id: 99,
    items: ['mouse', 'keyboard', 'monitor']
});Code language: JavaScript (javascript)

Contoh Penggunaan Destructuring dalam Real-World

1. API Response Handling

function handleResponse({ status, data: { user, token } }) {
    console.log(status);
    console.log(user);
    console.log(token);
}Code language: JavaScript (javascript)

2. Function dengan Object Config

function createServer({
    port = 3000,
    host = 'localhost'
}) {
    console.log(`Server berjalan di http://${host}:${port}`);
}

createServer({});Code language: JavaScript (javascript)

3. Event Listener di Browser

document.addEventListener('click', ({ clientX, clientY }) => {
    console.log(clientX, clientY);
});Code language: JavaScript (javascript)

4. Optimasi Penulisan Helper Function

const user = { id: 1, name: 'Aris', role: 'admin' };

function printRole({ role }) {
    console.log(role);
}

printRole(user);Code language: JavaScript (javascript)

Best Practice Destructuring Pada Parameter Function

  • Gunakan destructuring untuk parameter object yang banyak
    Lebih mudah dibaca daripada daftar parameter panjang.

  • Gunakan default value untuk membuat function lebih aman
    Mencegah undefined error.

  • Hindari destructuring yang terlalu dalam
    Jika terlalu kompleks, buat variabel terpisah untuk meningkatkan keterbacaan.

  • Gunakan object destructuring untuk parameter opsional
    Flexible dan mudah dipahami.

  • Hindari destructuring pada function yang dipanggil ribuan kali dalam loop berat
    Karena destructuring menambah sedikit overhead.

Destructuring dalam parameter function adalah teknik yang sangat membantu dalam menulis kode JavaScript yang lebih bersih, modern, dan mudah dirawat. Dengan teknik ini, kamu tidak hanya mempercepat proses coding tetapi juga meningkatkan kejelasan struktur data yang digunakan dalam sebuah function.

Jika dipahami dan diterapkan dengan tepat, destructuring dapat meningkatkan kualitas kode secara signifikan, terutama pada aplikasi besar berbasis JavaScript modern.

Destructuring pada Array Method (map, filter, reduce)

Salah satu penggunaan destructuring paling praktis dan sering dijumpai dalam JavaScript modern adalah pada array method seperti map, filter, dan reduce. Metode-metode ini sering dipakai untuk mengolah data dalam bentuk array, terutama dalam aplikasi frontend (React, Vue, Svelte), backend (Node.js), maupun dalam proses manipulasi data secara umum.

Dengan destructuring, kita bisa mengambil nilai tertentu dari item array atau object yang berada di dalam array — tanpa harus mengaksesnya satu per satu menggunakan titik (.) atau indeks ([]) secara manual.

Pada bagian ini, kita akan membahas:

  • Manfaat destructuring pada array method
  • Destructuring pada map()
  • Destructuring pada filter()
  • Destructuring pada reduce()
  • Contoh kasus nyata dalam aplikasi
  • Best practice

Mari kita mulai.

Kenapa Destructuring di Array Method Penting?

Array method sering berisi callback yang menerima parameter seperti:

(item) => { ... }Code language: PHP (php)

Jika item adalah object, destructuring memungkinkan kita langsung mengambil properti yang dibutuhkan:

Tanpa destructuring:

users.map(user => user.name)Code language: JavaScript (javascript)

Dengan destructuring:

users.map(({ name }) => name)Code language: JavaScript (javascript)

Lebih pendek, lebih bersih, lebih mudah dibaca.

Destructuring pada map()

Metode map() digunakan untuk membuat array baru dari hasil transformasi setiap item.

Contoh 1 — Destructuring Object di map()

const users = [
    { id: 1, name: 'Aris', age: 25 },
    { id: 2, name: 'Budi', age: 30 },
    { id: 3, name: 'Citra', age: 28 }
];

const names = users.map(({ name }) => name);

console.log(names);Code language: JavaScript (javascript)

Output:

['Aris', 'Budi', 'Citra']Code language: JSON / JSON with Comments (json)

Contoh 2 — Mengambil Banyak Properti

const userSummaries = users.map(({ name, age }) => {
    return `${name} berumur ${age} tahun`;
});Code language: JavaScript (javascript)

Contoh 3 — Destructuring Array dalam map()

const coordinates = [
    [10, 20],
    [5, 15],
    [7, 30]
];

const formatted = coordinates.map(([x, y]) => `X=${x}, Y=${y}`);

console.log(formatted);Code language: JavaScript (javascript)

Destructuring pada filter()

Metode filter() digunakan untuk memilih item yang memenuhi kondisi tertentu.

Contoh 1 — Filter Berdasarkan Properti Object

Tanpa destructuring:

users.filter(user => user.age > 25)Code language: JavaScript (javascript)

Dengan destructuring:

const adults = users.filter(({ age }) => age > 25);Code language: JavaScript (javascript)

Contoh 2 — Filter Berdasarkan Beberapa Properti

const selected = users.filter(({ age, name }) => {
    return age > 20 && name.startsWith('A');
});Code language: JavaScript (javascript)

Contoh 3 — Filter Data Array

const scores = [
    [1, 90],
    [2, 70],
    [3, 85]
];

const highScores = scores.filter(([id, score]) => score >= 85);

console.log(highScores);Code language: JavaScript (javascript)

Destructuring pada reduce()

Metode reduce() adalah array method paling fleksibel karena bisa digunakan untuk apa pun, mulai dari menjumlahkan angka, mengelompokkan data, hingga membuat struktur baru.

Destructuring menjadikannya lebih mudah dibaca.

Contoh 1 — Menjumlahkan Properti Tertentu

Tanpa destructuring:

scores.reduce((acc, item) => acc + item.score, 0)Code language: JavaScript (javascript)

Dengan destructuring:

const players = [
    { name: 'Aris', score: 80 },
    { name: 'Budi', score: 95 },
    { name: 'Citra', score: 75 }
];

const totalScore = players.reduce((acc, { score }) => acc + score, 0);

console.log(totalScore);Code language: JavaScript (javascript)

Contoh 2 — Mengelompokkan Data (Grouping)

const orders = [
    { id: 1, status: 'pending' },
    { id: 2, status: 'success' },
    { id: 3, status: 'pending' },
    { id: 4, status: 'success' }
];

const grouped = orders.reduce((acc, { status }) => {
    acc[status] = (acc[status] || 0) + 1;
    return acc;
}, {});

console.log(grouped);Code language: JavaScript (javascript)

Output:

{ pending: 2, success: 2 }Code language: CSS (css)

Contoh 3 — Destructuring Array dalam reduce()

const numbers = [10, 20, 30];

const sum = numbers.reduce((acc, value) => acc + value, 0);

console.log(sum);Code language: JavaScript (javascript)

Contoh 4 — Complex reduce dengan Nested Destructuring

const products = [
    { id: 1, detail: { price: 20000 } },
    { id: 2, detail: { price: 50000 } },
    { id: 3, detail: { price: 15000 } }
];

const total = products.reduce((acc, { detail: { price } }) => acc + price, 0);

console.log(total);Code language: JavaScript (javascript)

Contoh Kasus Nyata Destructuring pada Array Method

1. Memproses data API

const response = [
    { user: { name: 'Aris', age: 25 } },
    { user: { name: 'Budi', age: 30 } }
];

const names = response.map(({ user: { name } }) => name);Code language: JavaScript (javascript)

2. Membersihkan data sebelum dikirim ke server

const cleanData = users.map(({ id, name }) => ({ id, name }));Code language: JavaScript (javascript)

3. Mengubah array object menjadi key-value map

const userMap = users.reduce((acc, { id, name }) => {
    acc[id] = name;
    return acc;
}, {});Code language: JavaScript (javascript)

Best Practice Destructuring di Array Method

  • Gunakan destructuring hanya ketika properti yang dibutuhkan jelas
    Callback tetap harus mudah dibaca.

  • Hindari nested destructuring yang terlalu dalam
    Jika callback menjadi terlalu rumit → pisahkan dulu.

  • Gunakan default value jika data tidak pasti
    Menghindari error undefined.

const users = data.map(({ name = 'Guest' }) => name);Code language: JavaScript (javascript)
  • Untuk transformasi kompleks, gunakan reduce + destructuring dengan hati-hati
    Jaga readability.

  • Destructuring sangat cocok untuk data API
    Terutama jika format respons kompleks

Destructuring dalam array method seperti map, filter, dan reduce merupakan kemampuan penting dalam JavaScript modern. Teknik ini membuat kode lebih bersih, efisien, dan mudah dibaca, terutama saat menangani data dalam bentuk array object—sebuah kebutuhan yang hampir selalu muncul di dunia development saat ini.

Destructuring bukan hanya membuat kode lebih pendek, tetapi juga mengurangi potensi error akibat akses properti berulang dan mempermudah proses transformasi data.

Perbedaan Destructuring Array vs Object

Destructuring pada JavaScript dapat dilakukan pada array maupun object, namun keduanya memiliki karakteristik serta aturan yang berbeda. Memahami perbedaan ini sangat penting agar tidak terjadi error atau perilaku yang tidak sesuai harapan saat mengekstrak data dari struktur kompleks.

Perbedaan Dasar Destructuring Array dan Object

Destructuring Array

  • Digunakan untuk mengambil nilai berdasarkan urutan/index.
  • Struktur penulisan menggunakan tanda kurung siku [ ].

Contoh:

const colors = ["red", "green", "blue"];
const [first, second, third] = colors;

console.log(first);  // red
console.log(second); // green
console.log(third);  // blueCode language: JavaScript (javascript)

Destructuring Object

  • Digunakan untuk mengambil nilai berdasarkan nama property (key).
  • Struktur penulisan menggunakan tanda kurung kurawal { }.

Contoh:

const user = {
  name: "Aris",
  age: 25
};

const { name, age } = user;

console.log(name); // Aris
console.log(age);  // 25Code language: JavaScript (javascript)

Berdasarkan Urutan vs Berdasarkan Nama

Array → berdasarkan posisi

Jika urutannya salah, maka hasilnya juga salah.

const arr = [10, 20, 30];
const [b, a] = arr;

console.log(b); // 10
console.log(a); // 20   (bukan 30)Code language: JavaScript (javascript)

Object → berdasarkan nama

Meski posisinya diacak, hasil tetap sama selama nama key cocok.

const obj = { x: 1, y: 2 };

const { y, x } = obj;

console.log(y); // 2
console.log(x); // 1Code language: JavaScript (javascript)

Default Value pada Array vs Object

Array default:

Bekerja berdasarkan urutan index.

const arr = [100];
const [a, b = 200] = arr;

console.log(a); // 100
console.log(b); // 200Code language: JavaScript (javascript)

Object default:

Bekerja berdasarkan nama property.

const user = { name: "Aris" };
const { name, age = 30 } = user;

console.log(name); // Aris
console.log(age);  // 30Code language: JavaScript (javascript)

Mengganti Nama Variable Saat Destructuring

Array

Tidak bisa mengganti nama seperti object (karena berbasis posisi), namun kamu bisa memilih nama variabel sesukamu:

const arr = [1, 2];
const [foo, bar] = arr;

console.log(foo, bar); // 1 2Code language: JavaScript (javascript)

Object

Bisa mengganti nama variabel menggunakan :

const user = { name: "Aris", age: 25 };

const { name: username, age: userAge } = user;

console.log(username); // Aris
console.log(userAge);  // 25Code language: JavaScript (javascript)

Ini salah satu perbedaan paling penting.

Kasus Umum yang Sering Membingungkan

1. Destructuring array dengan skip value

const arr = ["a", "b", "c"];
const [ , second] = arr;

console.log(second); // bCode language: JavaScript (javascript)

2. Destructuring object dengan property tidak ada

const obj = { title: "Book" };
const { title, price } = obj;

console.log(price); // undefinedCode language: JavaScript (javascript)

3. Nama variable tidak boleh sama dengan nama property saat destructuring object (kecuali rename)

const person = { name: "Aris" };

// Error jika ingin memisahkan namanya namun variabel sudah ada
const { name: username } = person;Code language: JavaScript (javascript)

Tabel Perbandingan Lengkap

FiturArray DestructuringObject Destructuring
BerdasarkanUrutan/indexNama property (key)
Sintaks[ ]{ }
Boleh skip?Ya ([ , second])Tidak bernilai jika key tidak ada
Default valueBerdasarkan urutanBerdasarkan nama key
Rename variableTidak pakai format khususMenggunakan :
Harus match dengan?PosisiNama property
Cocok untukList, hasil API berbentuk array, koordinatObject data, konfigurasi, profile user

Kesimpulan

Destructuring adalah salah satu fitur modern JavaScript yang memberikan cara lebih ringkas, bersih, dan efisien dalam mengekstrak data dari array maupun object. Fitur ini bukan lagi sekadar sintaks “pemanis”, tetapi sudah menjadi standar dalam penulisan kode JavaScript modern, terutama ketika bekerja dengan API, data kompleks, modularisasi, serta pengembangan berbasis framework seperti React, Vue, Svelte, dan Node.js.

1 JavaScript Dasar

2 JavaScript Menengah

3 JavaScript Lanjutan

Level Lanjutan memperkenalkan fitur modern JavaScript seperti ES6+, arrow function, destructuring, spread operator, template literal, closures, dan konsep scope serta hoisting. Level ini membantu pengguna memahami dasar penting JavaScript modern yang banyak digunakan pada pengembangan web saat ini, sehingga dapat menulis kode yang lebih efisien, bersih, dan mudah dikelola.

4 JavaScript Mahir

5 JavaScript Ahli

Comments

Congrats, you have the opportunity to be the first commenter on this article. Have questions or suggestions? Please leave a comment to start discussion.

Leave comment

Alamat email Anda tidak akan dipublikasikan. Required fields are marked *

news-1701

yakinjp

yakinjp

rtp yakinjp

yakinjp

yakinjp

yakin jp

yakinjp id

maujp

maujp

maujp

\

sabung ayam online

sabung ayam online

SLOT MAHJONG

sabung ayam online

invoice 00026

invoice 00027

invoice 00028

invoice 00029

invoice 00030

invoice 00031

invoice 00032

invoice 00033

invoice 00034

invoice 00035

invoice 00036

invoice 00037

invoice 00038

invoice 00039

invoice 00040

invoice 00041

invoice 00042

invoice 00043

invoice 00044

invoice 00045

invoice 00046

invoice 00047

invoice 00048

invoice 00049

invoice 00050

invoice 00051

invoice 00052

invoice 00053

invoice 00054

invoice 00055

article 2000021

article 2000022

article 2000023

article 2000024

article 2000025

article 2000026

article 2000027

article 2000028

article 2000029

article 2000030

article 2000031

article 2000032

article 2000033

article 2000034

article 2000035

article 2000036

article 2000037

article 2000038

article 2000039

article 2000040

article 2000041

article 2000042

article 2000043

article 2000044

article 2000045

article 2000046

article 2000047

article 2000048

article 2000049

article 2000050

article 2000051

article 2000052

article 2000053

article 2000054

article 2000055

article 2000056

article 2000057

article 2000058

article 2000059

article 2000060

article 2000061

article 2000062

article 2000063

article 2000064

article 2000065

article 2000066

article 2000067

article 2000068

article 2000069

article 2000070

article 2000071

article 2000072

article 2000073

article 2000074

article 2000075

article 2000076

article 2000077

article 2000078

article 2000079

article 2000080

pusdataru 00021

pusdataru 00022

pusdataru 00023

pusdataru 00024

pusdataru 00025

pusdataru 00026

pusdataru 00027

pusdataru 00028

pusdataru 00029

pusdataru 00030

pusdataru 00031

pusdataru 00032

pusdataru 00033

pusdataru 00034

pusdataru 00035

pusdataru 00036

pusdataru 00037

pusdataru 00038

pusdataru 00039

pusdataru 00040

pusdataru 00041

pusdataru 00042

pusdataru 00043

pusdataru 00044

pusdataru 00045

pusdataru 00046

pusdataru 00047

pusdataru 00048

pusdataru 00049

pusdataru 00050

pusdataru 00051

pusdataru 00052

pusdataru 00053

pusdataru 00054

pusdataru 00055

pusdataru 00056

pusdataru 00057

pusdataru 00058

pusdataru 00059

pusdataru 00060

article 00000031

article 00000032

article 00000033

article 00000034

article 00000035

article 00000036

article 00000037

article 00000038

article 00000039

article 00000040

article 00000041

article 00000042

article 00000043

article 00000044

article 00000045

article 00000046

article 00000047

article 00000048

article 00000049

article 00000050

article 00000051

article 00000052

article 00000053

article 00000054

article 00000055

article 00000056

article 00000057

article 00000058

article 00000059

article 00000060

article 00000061

article 00000062

article 00000063

article 00000064

article 00000065

article 00000066

article 00000067

article 00000068

article 00000069

article 00000070

article 00000071

article 00000072

article 00000073

article 00000074

article 00000075

article 00000076

article 00000077

article 00000078

article 00000079

article 00000080

pemohonan 000001

pemohonan 000002

pemohonan 000003

pemohonan 000004

pemohonan 000005

pemohonan 000006

pemohonan 000007

pemohonan 000008

pemohonan 000009

pemohonan 000010

pemohonan 000011

pemohonan 000012

pemohonan 000013

pemohonan 000014

pemohonan 000015

pemohonan 000016

pemohonan 000017

pemohonan 000018

pemohonan 000019

pemohonan 000020

pemohonan 000021

pemohonan 000022

pemohonan 000023

pemohonan 000024

pemohonan 000025

pemohonan 000026

pemohonan 000027

pemohonan 000028

pemohonan 000029

pemohonan 000030

artikel 000000081

artikel 000000082

artikel 000000083

artikel 000000084

artikel 000000085

artikel 000000086

artikel 000000087

artikel 000000088

artikel 000000089

artikel 000000090

artikel 000000091

artikel 000000092

artikel 000000093

artikel 000000094

artikel 000000095

artikel 000000096

artikel 000000097

artikel 000000098

artikel 000000099

artikel 000000100

artikel 000000101

artikel 000000102

artikel 000000103

artikel 000000104

artikel 000000105

artikel 000000106

artikel 000000107

artikel 000000108

artikel 000000109

artikel 000000110

artikel 000000111

artikel 000000112

artikel 000000113

artikel 000000114

artikel 000000115

artikel 000000116

artikel 000000117

artikel 000000118

artikel 000000119

artikel 000000120

pengadilan 000061

pengadilan 000062

pengadilan 000063

pengadilan 000064

pengadilan 000065

pengadilan 000066

pengadilan 000067

pengadilan 000068

pengadilan 000069

pengadilan 000070

pengadilan 000071

pengadilan 000072

pengadilan 000073

pengadilan 000074

pengadilan 000075

pengadilan 000076

pengadilan 000077

pengadilan 000078

pengadilan 000079

pengadilan 000080

pengadilan 000081

pengadilan 000082

pengadilan 000083

pengadilan 000084

pengadilan 000085

pengadilan 000086

pengadilan 000087

pengadilan 000088

pengadilan 000089

pengadilan 000090

perkara 0000066

perkara 0000067

perkara 0000068

perkara 0000069

perkara 0000070

perkara 0000071

perkara 0000072

perkara 0000073

perkara 0000074

perkara 0000075

perkara 0000076

perkara 0000077

perkara 0000078

perkara 0000079

perkara 0000080

perkara 0000081

perkara 0000082

perkara 0000083

perkara 0000084

perkara 0000085

perkara 0000086

perkara 0000087

perkara 0000088

perkara 0000089

perkara 0000090

article 0000021

article 0000022

article 0000023

article 0000024

article 0000025

article 0000026

article 0000027

article 0000028

article 0000029

article 0000030

article 0000031

article 0000032

article 0000033

article 0000034

article 0000035

article 0000036

article 0000037

article 0000038

article 0000039

article 0000040

article 0000041

article 0000042

article 0000043

article 0000044

article 0000045

article 0000046

article 0000047

article 0000048

article 0000049

article 0000050

article 0000051

article 0000052

article 0000053

article 0000054

article 0000055

article 0000056

article 0000057

article 0000058

article 0000059

article 0000060

article 0000061

article 0000062

article 0000063

article 0000064

article 0000065

article 0000066

article 0000067

article 0000068

article 0000069

article 0000070

article 3000031

article 3000032

article 3000033

article 3000034

article 3000035

article 3000036

article 3000037

article 3000038

article 3000039

article 3000040

article 3000041

article 3000042

article 3000043

article 3000044

article 3000045

article 3000046

article 3000047

article 3000048

article 3000049

article 3000050

article 3000051

article 3000052

article 3000053

article 3000054

article 3000055

article 3000056

article 3000057

article 3000058

article 3000059

article 3000060

news-1701
news-1701

yakinjp

yakinjp

rtp yakinjp

yakinjp

yakinjp

yakin jp

yakinjp id

maujp

maujp

maujp

\

sabung ayam online

sabung ayam online

SLOT MAHJONG

sabung ayam online

invoice 00026

invoice 00027

invoice 00028

invoice 00029

invoice 00030

invoice 00031

invoice 00032

invoice 00033

invoice 00034

invoice 00035

invoice 00036

invoice 00037

invoice 00038

invoice 00039

invoice 00040

invoice 00041

invoice 00042

invoice 00043

invoice 00044

invoice 00045

invoice 00046

invoice 00047

invoice 00048

invoice 00049

invoice 00050

invoice 00051

invoice 00052

invoice 00053

invoice 00054

invoice 00055

article 2000021

article 2000022

article 2000023

article 2000024

article 2000025

article 2000026

article 2000027

article 2000028

article 2000029

article 2000030

article 2000031

article 2000032

article 2000033

article 2000034

article 2000035

article 2000036

article 2000037

article 2000038

article 2000039

article 2000040

article 2000041

article 2000042

article 2000043

article 2000044

article 2000045

article 2000046

article 2000047

article 2000048

article 2000049

article 2000050

article 2000051

article 2000052

article 2000053

article 2000054

article 2000055

article 2000056

article 2000057

article 2000058

article 2000059

article 2000060

article 2000061

article 2000062

article 2000063

article 2000064

article 2000065

article 2000066

article 2000067

article 2000068

article 2000069

article 2000070

article 2000071

article 2000072

article 2000073

article 2000074

article 2000075

article 2000076

article 2000077

article 2000078

article 2000079

article 2000080

pusdataru 00021

pusdataru 00022

pusdataru 00023

pusdataru 00024

pusdataru 00025

pusdataru 00026

pusdataru 00027

pusdataru 00028

pusdataru 00029

pusdataru 00030

pusdataru 00031

pusdataru 00032

pusdataru 00033

pusdataru 00034

pusdataru 00035

pusdataru 00036

pusdataru 00037

pusdataru 00038

pusdataru 00039

pusdataru 00040

pusdataru 00041

pusdataru 00042

pusdataru 00043

pusdataru 00044

pusdataru 00045

pusdataru 00046

pusdataru 00047

pusdataru 00048

pusdataru 00049

pusdataru 00050

pusdataru 00051

pusdataru 00052

pusdataru 00053

pusdataru 00054

pusdataru 00055

pusdataru 00056

pusdataru 00057

pusdataru 00058

pusdataru 00059

pusdataru 00060

article 00000031

article 00000032

article 00000033

article 00000034

article 00000035

article 00000036

article 00000037

article 00000038

article 00000039

article 00000040

article 00000041

article 00000042

article 00000043

article 00000044

article 00000045

article 00000046

article 00000047

article 00000048

article 00000049

article 00000050

article 00000051

article 00000052

article 00000053

article 00000054

article 00000055

article 00000056

article 00000057

article 00000058

article 00000059

article 00000060

article 00000061

article 00000062

article 00000063

article 00000064

article 00000065

article 00000066

article 00000067

article 00000068

article 00000069

article 00000070

article 00000071

article 00000072

article 00000073

article 00000074

article 00000075

article 00000076

article 00000077

article 00000078

article 00000079

article 00000080

pemohonan 000001

pemohonan 000002

pemohonan 000003

pemohonan 000004

pemohonan 000005

pemohonan 000006

pemohonan 000007

pemohonan 000008

pemohonan 000009

pemohonan 000010

pemohonan 000011

pemohonan 000012

pemohonan 000013

pemohonan 000014

pemohonan 000015

pemohonan 000016

pemohonan 000017

pemohonan 000018

pemohonan 000019

pemohonan 000020

pemohonan 000021

pemohonan 000022

pemohonan 000023

pemohonan 000024

pemohonan 000025

pemohonan 000026

pemohonan 000027

pemohonan 000028

pemohonan 000029

pemohonan 000030

artikel 000000081

artikel 000000082

artikel 000000083

artikel 000000084

artikel 000000085

artikel 000000086

artikel 000000087

artikel 000000088

artikel 000000089

artikel 000000090

artikel 000000091

artikel 000000092

artikel 000000093

artikel 000000094

artikel 000000095

artikel 000000096

artikel 000000097

artikel 000000098

artikel 000000099

artikel 000000100

artikel 000000101

artikel 000000102

artikel 000000103

artikel 000000104

artikel 000000105

artikel 000000106

artikel 000000107

artikel 000000108

artikel 000000109

artikel 000000110

artikel 000000111

artikel 000000112

artikel 000000113

artikel 000000114

artikel 000000115

artikel 000000116

artikel 000000117

artikel 000000118

artikel 000000119

artikel 000000120

pengadilan 000061

pengadilan 000062

pengadilan 000063

pengadilan 000064

pengadilan 000065

pengadilan 000066

pengadilan 000067

pengadilan 000068

pengadilan 000069

pengadilan 000070

pengadilan 000071

pengadilan 000072

pengadilan 000073

pengadilan 000074

pengadilan 000075

pengadilan 000076

pengadilan 000077

pengadilan 000078

pengadilan 000079

pengadilan 000080

pengadilan 000081

pengadilan 000082

pengadilan 000083

pengadilan 000084

pengadilan 000085

pengadilan 000086

pengadilan 000087

pengadilan 000088

pengadilan 000089

pengadilan 000090

perkara 0000066

perkara 0000067

perkara 0000068

perkara 0000069

perkara 0000070

perkara 0000071

perkara 0000072

perkara 0000073

perkara 0000074

perkara 0000075

perkara 0000076

perkara 0000077

perkara 0000078

perkara 0000079

perkara 0000080

perkara 0000081

perkara 0000082

perkara 0000083

perkara 0000084

perkara 0000085

perkara 0000086

perkara 0000087

perkara 0000088

perkara 0000089

perkara 0000090

article 0000021

article 0000022

article 0000023

article 0000024

article 0000025

article 0000026

article 0000027

article 0000028

article 0000029

article 0000030

article 0000031

article 0000032

article 0000033

article 0000034

article 0000035

article 0000036

article 0000037

article 0000038

article 0000039

article 0000040

article 0000041

article 0000042

article 0000043

article 0000044

article 0000045

article 0000046

article 0000047

article 0000048

article 0000049

article 0000050

article 0000051

article 0000052

article 0000053

article 0000054

article 0000055

article 0000056

article 0000057

article 0000058

article 0000059

article 0000060

article 0000061

article 0000062

article 0000063

article 0000064

article 0000065

article 0000066

article 0000067

article 0000068

article 0000069

article 0000070

article 3000031

article 3000032

article 3000033

article 3000034

article 3000035

article 3000036

article 3000037

article 3000038

article 3000039

article 3000040

article 3000041

article 3000042

article 3000043

article 3000044

article 3000045

article 3000046

article 3000047

article 3000048

article 3000049

article 3000050

article 3000051

article 3000052

article 3000053

article 3000054

article 3000055

article 3000056

article 3000057

article 3000058

article 3000059

article 3000060

news-1701
content-1701

sabung ayam online

yakinjp

yakinjp

rtp yakinjp

slot thailand

yakinjp

yakinjp

yakin jp

yakinjp id

maujp

maujp

maujp

maujp

slot mahjong

SGP Pools

slot mahjong

sabung ayam online

slot mahjong

SLOT THAILAND

article 888000081

article 888000082

article 888000083

article 888000084

article 888000085

article 888000086

article 888000087

article 888000088

article 888000089

article 888000090

article 888000091

article 888000092

article 888000093

article 888000094

article 888000095

article 888000096

article 888000097

article 888000098

article 888000099

article 888000100

cuaca 898100126

cuaca 898100127

cuaca 898100128

cuaca 898100129

cuaca 898100130

cuaca 898100131

cuaca 898100132

cuaca 898100133

cuaca 898100134

cuaca 898100135

cuaca 898100136

cuaca 898100137

cuaca 898100138

cuaca 898100139

cuaca 898100140

cuaca 898100141

cuaca 898100142

cuaca 898100143

cuaca 898100144

cuaca 898100145

cuaca 898100146

cuaca 898100147

cuaca 898100148

cuaca 898100149

cuaca 898100150

cuaca 898100151

cuaca 898100152

cuaca 898100153

cuaca 898100154

cuaca 898100155

cuaca 898100156

cuaca 898100157

cuaca 898100158

cuaca 898100159

cuaca 898100160

cuaca 898100161

cuaca 898100162

cuaca 898100163

cuaca 898100164

cuaca 898100165

cuaca 898100166

cuaca 898100167

cuaca 898100168

cuaca 898100169

cuaca 898100170

cuaca 898100171

cuaca 898100172

cuaca 898100173

cuaca 898100174

cuaca 898100175

article 710000151

article 710000152

article 710000153

article 710000154

article 710000155

article 710000156

article 710000157

article 710000158

article 710000159

article 710000160

article 710000161

article 710000162

article 710000163

article 710000164

article 710000165

article 710000166

article 710000167

article 710000168

article 710000169

article 710000170

article 710000171

article 710000172

article 710000173

article 710000174

article 710000175

article 710000176

article 710000177

article 710000178

article 710000179

article 710000180

article 710000181

article 710000182

article 710000183

article 710000184

article 710000185

article 710000186

article 710000187

article 710000188

article 710000189

article 710000190

article 710000191

article 710000192

article 710000193

article 710000194

article 710000195

article 710000196

article 710000197

article 710000198

article 710000199

article 710000200

psda 438000036

psda 438000037

psda 438000038

psda 438000039

psda 438000040

psda 438000041

psda 438000042

psda 438000043

psda 438000044

psda 438000045

psda 438000046

psda 438000047

psda 438000048

psda 438000049

psda 438000050

psda 438000051

psda 438000052

psda 438000053

psda 438000054

psda 438000055

psda 438000056

psda 438000057

psda 438000058

psda 438000059

psda 438000060

psda 438000061

psda 438000062

psda 438000063

psda 438000064

psda 438000065

psda 438000066

psda 438000067

psda 438000068

psda 438000069

psda 438000070

psda 438000071

psda 438000072

psda 438000073

psda 438000074

psda 438000075

psda 438000076

psda 438000077

psda 438000078

psda 438000079

psda 438000080

psda 438000081

psda 438000082

psda 438000083

psda 438000084

psda 438000085

psda 438000086

psda 438000087

psda 438000088

psda 438000089

psda 438000090

psda 438000091

psda 438000092

psda 438000093

psda 438000094

psda 438000095

psda 438000096

psda 438000097

psda 438000098

psda 438000099

psda 438000100

psda 438000101

psda 438000102

psda 438000103

psda 438000104

psda 438000105

psda 438000106

psda 438000107

psda 438000108

psda 438000109

content-1701