DOM Nodelist sendiri adalah kumpulan Node yang diekstrak melalui dokumen HTML. Jika kalian sudah pernah mempelajari HTML Collection
sebelumnya, maka kalian mungkin bisa melihat perbedaan yang tidak terlalu jauh dengan Nodelist
. Pembuatan Nodelist
sendiri biasanya menggunakan querySelectorAll()
Nodelist memiliki beberapa method seperti :
- Nodelist.item() :
Digunakan untuk mengembalikan item dalam daftar menurut indeksnya.
- Nodelist.entries() :
Berguna untuk mengembalikan iterator untuk mendapatkan key atau value.
- Nodelist.forEach() :
Digunakan untuk mengambil semua elemen yang ada pada Nodelist.
- Nodelist.keys() :
Berguna untuk mengembalikan iterator keys dari key atau value berupa urutan index 0 dan seterusnya.
- Nodelist.values() :
Berguna untuk mengembalikan iterator values dari key atau value yang ada pada collection.
HTML :
<p>Halo Dunia!</p>
<p>Halo Bellshade!</p>
<p id="test"></p>
Javascript :
const nodeList = document.querySelectorAll("p");
const test = document.getElementById("test");
// Mengambil elemen nodelist menggunakan index
const text = document.createTextNode(`Saya berkata : ${nodeList[0].innerHTML} & ${nodeList[1].innerHTML}`);
test.appendChild(text);
// Membuat semua elemen <p> memiliki text berwarna biru
for (let i = 0; i < nodeList.length; i++) {
nodeList[i].style.color = "blue";
}
// Membuat semua elemen <p> memiliki background hitam
nodeList.forEach((node) => (node.style.backgroundColor = "black"));
Diawal kita buat terlebih dahulu beberapa elemen <p>
yang akan kita manipulasi dengan DOM, lanjut ke Javascript kita mulai dengan menyeleksi elemen <p>
menggunakan querySelectorAll()
dan kita juga mengambil elemen <p>
satunya dengan id test
menggunakan getElementById()
. Langkah selanjutnya kita akan gabungkan elemen yang ada pada Nodelist
menggunakan properti innerHTML
, terlihat pada implementasi elemen Nodelist
kita menggunakan [0]
dan [1]
karena pada dasarnya elemen Nodelist
memiliki index yang sama seperti Array
.
Kita juga menggunakan for loop
untuk mengambil semua elemen yang ada pada Nodelist
untuk memberi warna biru pada text elemen <p>
dan penggunaan forEach
disini sama halnya dengan for loop
, yakni mengambil semua elemen yang ada pada Nodelist
dan memanipulasi elemen <p>
dengan memberi background hitam.
Hasil:
HTML :
<input type="checkbox" />
<input type="checkbox" />
<input type="checkbox" />
Javascript :
const checkbox = document.querySelectorAll("input[type=checkbox]");
// Mengambil elemen nodelist menggunakan for of untuk memanipulasi checkbox agar terceklis untuk pertama kali
for (const check of checkbox) {
check.checked = true;
}
Pada studi kasus kedua ini kita ingin mengambil semua elemen input bertipe checkbox
, tentu dengan menggunakan Nodelist
akan menjadi lebih mudah karena kita bisa langsung mengambil semua inputnya. Pertama kita seleksi semua elemennya menggunakan querySelectorAll()
sama seperti studi kasus pertama, setelahnya kita akan menggunakan for of
untuk mengambil elemennya satu per satu untuk kita manipulasi checkboxnya agar terceklis untuk pertama kali.
Hasil:
Referensi: HTML DOM Nodelist W3School Referensi: HTML DOM Nodelist MDN