Peran Penting "Kunci" dalam Pemetaan Array
Jika Anda adalah seseorang yang cenderung mengabaikan pesan peringatan “setiap elemen harus memiliki kunci unik” saat memetakan array di React, penting untuk meluangkan waktu sejenak untuk memahami mengapa peringatan ini dimunculkan sejak awal.
Di React, saat merender daftar item menggunakan fungsi “Array.map()”, disarankan untuk menyediakan prop “key” yang unik untuk setiap item. Tapi kenapa?
Jawabannya adalah optimalisasi.
Mari kita pertimbangkan bahwa kita sedang membangun toko e-niaga tempat kita memiliki keranjang belanja dan menggunakan larik untuk menyimpan item yang telah ditambahkan pengguna ke keranjang belanja mereka. Array dapat diperbarui secara dinamis saat pengguna menambahkan atau menghapus item.
Katakanlah pengguna tersayang kita sedang berbelanja laptop baru dan saat ini memiliki 3 item di keranjangnya, yaitu 3 elemen array.
Sekarang misalkan pengguna menambahkan " headphone" ke trolinya. Sekarang kita menyimpan array dalam keadaan, saat pengguna menambahkan atau menghapus sesuatu dari array, React akan me-render ulang komponen sehingga UI dapat disinkronkan dengan nilai terbaru dari keadaan komponen tersebut.
Ini akan memainkan permainan "menemukan perbedaan" untuk mencari tahu apa yang telah berubah dari render sebelumnya dan memperbarui UI yang sesuai. Ini akan mendeteksi bahwa ada elemen baru di pohon DOM virtual saat ini yang tidak ada di pohon DOM virtual sebelumnya, dan akan menambahkan elemen baru ke DOM tanpa membandingkannya dengan elemen yang ada di larik (ini karena React telah membandingkan DOM virtual dan mengetahui bahwa item baru adalah satu-satunya elemen yang telah berubah). Kami tidak memiliki headphone, jadi kami memasukkannya. Mudah sekali!
Jadi sekarang susunan keranjang kita akan dipetakan seperti ini:
Tapi sekarang, katakanlah toko memungkinkan pengguna untuk mengurutkan barang di keranjang berdasarkan harga, dari rendah ke tinggi. Hasilnya, urutan item dalam keranjang berubah, dan keranjang sekarang ditampilkan sebagai berikut: mouse, headphone, keyboard, dan laptop.
Di sini, React sekali lagi harus membandingkan seluruh DOM virtual untuk menentukan perubahan, karena tidak ada cara lain untuk mengetahui bahwa elemen baru saja diurutkan ulang dan tidak ada satu pun elemen array yang berubah . Ini akan menghasilkan pohon DOM virtual baru yang mencerminkan urutan elemen yang baru. Ini kemudian akan membandingkan setiap elemen di pohon DOM virtual sebelumnya dengan elemen yang sesuai di pohon DOM virtual baru untuk menentukan perubahannya.
Bukankah lebih baik jika React dapat mengetahui perbedaan antara ketika elemen array baru saja disusun ulang dan ketika mereka benar-benar berubah (ditambah atau dihapus) dan juga elemen persis yang telah ditambahkan atau dihapus sehingga kita dapat mengoptimalkan perbedaan DOM virtual memproses dan meningkatkan kinerja?
Ya, kita bisa, dan jawabannya adalah melalui penyangga "kunci".
Katakanlah kita menambahkan kunci untuk setiap elemen dalam larik kita.
Jadi ketika React memperbarui array elemen, itu hanya akan membandingkan kunci elemen dalam array lama dan baru untuk menentukan elemen mana yang telah ditambahkan, dihapus, atau dipindahkan. React hanya akan melakukan perbandingan konten elemen yang lebih detail jika kunci tidak cocok atau jika tidak ada kunci yang ditentukan (perbandingan awal di mana kami tidak memiliki kunci).
Jadi, dalam arti tertentu, React masih melakukan perbandingan saat memperbarui sebuah array elemen, tetapi dengan membandingkan kunci daripada seluruh array, ini dapat mengoptimalkan proses pembaruan dan meningkatkan kinerja.
Perbandingan dengan kunci lebih cepat dan lebih efisien daripada membandingkan seluruh elemen, karena memungkinkan React dengan cepat menentukan elemen mana yang telah ditambahkan, dihapus, atau dipindahkan. Ini membantu meminimalkan jumlah pekerjaan yang perlu dilakukan React selama pembaruan dan memastikan bahwa pembaruan diproses seefisien mungkin.
Mengapa tidak menggunakan indeks sebagai kunci?
Callback dalam fungsi array.map() mengambil parameter yang disebut index, yang memberikan akses ke nilai indeks setiap elemen. Kita dapat mengatur kunci indeks elemen tertentu. Tapi itu tidak besar!
function Component()
const cart = ["Laptop," "Headphones"];
return (
<div>
cart.map((eachItem, index) =>
return h1 key=index>eachItem/h1>;
})}
</div>
);
}
export default component;
React berpikir seperti ini: jika key prop dari suatu elemen tidak berubah, saya tidak perlu melakukan pemeriksaan mendetail pada konten elemen tersebut. Saya berasumsi bahwa jika kuncinya tidak diperbarui, maka semuanya sama.
Math.random() — TIDAK!
Yah, kita mungkin berpikir bahwa menggunakan Math.random() untuk kunci adalah ide yang bagus, karena akan menghasilkan angka acak yang unik di antara semua kunci dalam larik itu. Tapi kita harus ingat bahwa kunci baru akan dibuat dengan setiap render, bahkan jika array itu sendiri tidak berubah . Hal ini dapat menyebabkan React salah berasumsi bahwa suatu elemen telah diubah atau ditambahkan. Ini menggagalkan tujuan penggunaan kunci karena React tidak dapat secara akurat membandingkan kunci di antara render untuk mengidentifikasi elemen mana yang benar-benar berubah.
Jadi, aturannya adalah memilih kunci yang stabil dan konsisten di antara render sehingga React dapat secara akurat membandingkan kunci di antara render untuk mengidentifikasi elemen mana yang telah diubah, ditambahkan, atau dihapus dari array. Jadi - tidak ada indeks, tidak ada Matematika. acak() ❌