JavaScript - Model Objek Dokumen atau DOM

Setiap halaman web berada di dalam jendela browser yang dapat dianggap sebagai objek.

Objek Dokumen mewakili dokumen HTML yang ditampilkan di jendela itu. Objek Dokumen memiliki berbagai properti yang merujuk ke objek lain yang memungkinkan akses dan modifikasi konten dokumen.

Cara konten dokumen diakses dan dimodifikasi disebut Document Object Model, atau DOM. Objek diatur dalam hierarki. Struktur hierarki ini berlaku untuk organisasi objek dalam dokumen Web.

  • Window object- Atas hierarki. Ini adalah elemen terluar dari hierarki objek.

  • Document object- Setiap dokumen HTML yang dimuat ke jendela menjadi objek dokumen. Dokumen tersebut berisi konten halaman.

  • Form object - Segala sesuatu yang dimasukkan dalam tag <form> ... </form> menyetel objek formulir.

  • Form control elements - Objek formulir berisi semua elemen yang ditentukan untuk objek itu seperti bidang teks, tombol, tombol radio, dan kotak centang.

Berikut ini hierarki sederhana dari beberapa objek penting -

Ada beberapa DOM yang ada. Bagian berikut menjelaskan masing-masing DOM ini secara mendetail dan menjelaskan bagaimana Anda dapat menggunakannya untuk mengakses dan mengubah konten dokumen.

  • The Legacy DOM - Ini adalah model yang diperkenalkan di versi awal bahasa JavaScript. Ini didukung dengan baik oleh semua browser, tetapi memungkinkan akses hanya ke bagian kunci tertentu dari dokumen, seperti formulir, elemen formulir, dan gambar.

  • DOM W3C - Model objek dokumen ini memungkinkan akses dan modifikasi semua konten dokumen dan distandarisasi oleh World Wide Web Consortium (W3C). Model ini didukung oleh hampir semua browser modern.

  • IE4 DOM - Model objek dokumen ini diperkenalkan pada browser Internet Explorer Microsoft Versi 4. IE 5 dan versi yang lebih baru menyertakan dukungan untuk sebagian besar fitur DOM W3C dasar.

Kompatibilitas DOM

Jika Anda ingin menulis skrip dengan fleksibilitas untuk menggunakan W3C DOM atau IE 4 DOM bergantung pada ketersediaannya, maka Anda dapat menggunakan pendekatan pengujian kemampuan yang terlebih dahulu memeriksa keberadaan metode atau properti untuk menentukan apakah browser memiliki kemampuan yang Anda inginkan. Misalnya -

if (document.getElementById) {
   // If the W3C method exists, use it
} else if (document.all) {
   // If the all[] array exists, use it
} else {
   // Otherwise use the legacy DOM
}