Rumah >hujung hadapan web >tutorial js >Memahami pemaparan dalam penyemak imbas: Bagaimanakah DOM dijana?
Dalam artikel sebelum ini kami belajar tentang DOM dan CSSOM, jika anda masih ragu-ragu tentang dua perkataan ini saya syorkan membaca dua siaran di bawah:
Untuk mengimbas kembali, DOM ialah struktur yang digunakan oleh penyemak imbas untuk memaparkan halaman kami. Walau bagaimanapun, data internet tidak dihantar dalam bentuk DOM, jadi perlu ada proses sebelum DOM sedia untuk digunakan oleh penyemak imbas.
Pada ketika ini anda mungkin tertanya-tanya bagaimana data bergerak di internet?
Setiap kali kami mengakses tapak web, pertukaran berlaku dalam corak yang kami panggil pelanggan x pelayan.
Dalam pertukaran ini, pelanggan (pelayar anda) meminta pelayan untuk mengakses tapak web www.cristiano.dev, yang bertindak balas dengan semua kandungan tapak web yang diminta, tetapi kandungan ini datang dalam bentuk bait dan dengan cara yang jauh daripada html/css/js yang kita tahu.
Apa yang akan diterima oleh penyemak imbas daripada pelayan ialah urutan bait.
Untuk coretan kecil html ini yang disediakan oleh pelayan:
<!doctype html> <html> <head> <title>Um título</title> </head> <body> <a href="#">Um link</a> <h1>Um cabeçalho</h1> </body> </html>
Pelayar akan menerima dalam bait sesuatu seperti ini:
3C21646F63747970652068746D6C3E0A3C68746D6C3E0A20203C686561643E0A202020203C7469746C653E556D2074C3AD74756C6F3C2F7469746C653E0A20203C2F686561643E0A20203C626F64793E0A202020203C6120687265663D2223223E556D206C696E6B3C2F613E0A202020203C68313E556D2063616265C3A7616C686F3C2F68313E0A20203C2F626F64793E0A3C2F68746D6C3E
Walau bagaimanapun, penyemak imbas tidak boleh memaparkan halaman dengan hanya maklumat ini. Untuk reka letak kami dipasang, penyemak imbas akan melakukan beberapa langkah sebelum mempunyai DOM.
Langkah-langkah ini ialah:
Dalam langkah ini penyemak imbas membaca data mentah daripada rangkaian atau cakera dan menukarnya kepada aksara berdasarkan pengekodan yang dinyatakan dalam fail, contohnya, UTF-8.
Pada asasnya ia adalah langkah di mana penyemak imbas menukar bait kepada kod dalam format yang kita tulis dalam kehidupan seharian kita.
Pada peringkat ini, penyemak imbas menukar rentetan aksara kepada unit kecil yang dipanggil token. Setiap permulaan, penghujung teg dan kandungan dikira, selain itu, setiap token mempunyai set peraturan tertentu.
Contohnya, teg mempunyai atribut yang berbeza daripada teg
Tanpa langkah ini, kami hanya akan mempunyai sekumpulan teks tanpa makna untuk penyemak imbas dan pada akhir proses ini html asas kami akan ditandakan seperti ini:
➔ Token: StartTag, Nama: p
Token ialah perkataan atau simbol individu dalam teks. "Tokenisasi" ialah proses memecahkan teks kepada perkataan, frasa atau simbol yang lebih kecil.
Langkah lexing (analisis leksikal) bertanggungjawab untuk menukar token kepada objek, tetapi ini bukan DOM lagi. Pada masa ini, penyemak imbas menjana bahagian terpencil DOM, di mana setiap teg akan diubah menjadi objek dengan atribut yang membawa maklumat yang berkaitan dengan atribut, teg induk, teg anak, dsb.
Hasilnya selepas lexing tag kami
ia akan menjadi seperti ini:
<!doctype html> <html> <head> <title>Um título</title> </head> <body> <a href="#">Um link</a> <h1>Um cabeçalho</h1> </body> </html>
Kami akhirnya mencapai peringkat pembinaan DOM!
Pada ketika ini, penyemak imbas akan mempertimbangkan perhubungan antara teg html dan akan menggabungkan nod ke dalam struktur data pepohon yang mewakili perhubungan ini secara hierarki. Sebagai contoh: objek html ialah ibu bapa objek badan, badan ialah ibu bapa objek perenggan, sehingga keseluruhan perwakilan dokumen dibuat.
Pada akhir pembinaan, contoh html kami menjadi pokok objek seperti ini:
3C21646F63747970652068746D6C3E0A3C68746D6C3E0A20203C686561643E0A202020203C7469746C653E556D2074C3AD74756C6F3C2F7469746C653E0A20203C2F686561643E0A20203C626F64793E0A202020203C6120687265663D2223223E556D206C696E6B3C2F613E0A202020203C68313E556D2063616265C3A7616C686F3C2F68313E0A20203C2F626F64793E0A3C2F68746D6C3E
Proses untuk membina DOM adalah rumit dan berlaku dalam langkah berikut:
Proses yang serupa juga berlaku untuk CSSOM, yang terdiri daripada penukaran, tokenisasi dan lexing.
Anda pasti tertanya-tanya di mana anda akan mengaplikasikan pengetahuan ini sepanjang perkembangan hari ke hari anda...
Memang benar maklumat jenis ini tidak akan diminta dengan kerap, tetapi adalah penting untuk memahami cara penyemak imbas, alat kerja bahagian hadapan utama, berfungsi pada dasarnya.
Pengetahuan ini juga akan menjadi sangat berharga untuk memahami topik seterusnya yang akan kami bahas di sini: Cat, cat semula, aliran dan aliran semula.
Terima kasih kerana tiba di sini!
Saya harap anda belajar sesuatu yang baharu sepanjang pembacaan ini.
Jumpa lagi nanti!
Membina Model Objek
Menyahbina Web: Perenderan Halaman
Atas ialah kandungan terperinci Memahami pemaparan dalam penyemak imbas: Bagaimanakah DOM dijana?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!