Rumah > Artikel > hujung hadapan web > Kuasai sepenuhnya perbezaan dan penggunaan DOM dan BOM dalam JavaScript
Artikel ini membawakan anda pengetahuan yang berkaitan tentang javascript terutamanya memperkenalkan DOM dan BOM serta perbezaan dan penggunaannya. Saya harap ia dapat membantu semua orang.
[Cadangan berkaitan: tutorial video javascript]
Pada permulaan artikel, saya ingin menyebut secara amnya, apa itu DOM dan apakah itu BOM, kerana artikel .
Walau bagaimanapun, sebelumbercakap tentang apa itu DOM dan apa itu BOM , sila benarkan saya menunjukkan kepada anda keseluruhan struktur Javascript :
Dalam gambar di atas, kita dapat melihat bahawa terdapatempat elemen: JavaScript, ECMAScript, DOM dan BOM, jadi apakah kaitan antara keempat-empat elemen tersebut? Gunakan persamaan untuk meringkaskan hubungan antara mereka:
MariJavaScript = ECMAscript BOM DOM
berurusan dengan mereka satu demi satu Untuk berikan gambaran keseluruhan :
Skrip ECMA:
ECMAScript ialah bahasa yang diterima pakai olehECMA International (dahulunya Persatuan Pengilang Komputer Eropah) ECMA -262 bahasa pengaturcaraan penskripan piawai , ia adalah standard JavaScript (pendek kata JS), dan penyemak imbas akan melaksanakan piawaian ini .
ECMAscript lebih seperti peraturan, menetapkan cara setiap penyemak imbas melaksanakan sintaks JavaScript , kerana kami tahu bahawa JavaScript ialah bahasa skrip yang dijalankan pada penyemak imbas! Terdapat peraturan, tetapi kami masih kekurangan cara untuk berinteraksi dengan setiap elemen pada halaman Pada masa ini, DOM berikut telah dilahirkan!
DOM:
DOM (Ringkasan dalam satu ayat:Model Objek Dokumen, Model Objek Dokumen) ialah bahasa bebas, antara muka pengaturcaraan aplikasi untuk mengendalikan xml, dokumen html.
Untuk JavaScript: Untukmendayakan JavaScript untuk mengendalikan Html, JavaScript mempunyai antara muka pengaturcaraan DOM sendiri.
DOM menyediakan JavaScript dengan "kaedah" untuk mengakses dan mengendalikan elemen HTML (Sebab saya tidak menggunakan antara muka perkataan adalah kerana saya takut sesetengah rakan akan melihat antara muka Ia adalah situasi yang menakutkan, tetapi sebenarnya penerangan yang paling tepat tentang ialah ia menyediakan antara muka untuk JavaScript )
BOM:
BOM ialahRingkasan dalam satu ayat:Model Objek Penyemak Imbas, model objek penyemak imbas . BOM ialah antara muka yang kelihatan mengawal kelakuan penyemak imbas.
Untuk JavaScript: Untukmembenarkan JavaScript mengawal kelakuan penyemak imbas, JavaScript mempunyai antara muka BOM sendiri.
BOM menyediakan JavaScript dengan "kaedah" untuk mengawal tingkah laku penyemak imbas.
Akhir sekali, antara tiga komponen JavaScript di atas,ECMscript ialah spesifikasi , manakala dua yang selebihnya menyediakan "kaedah", masing-masing Sesuai dengan elemen HTML dan pelayar , jadi di bawah kami menerangkan secara sistematik dua yang terakhir: DOM dan BOM Memandangkan ia adalah untuk pemula, saya akan membuat penjelasan berikut semudah mungkin, walaupun anda tak tahu asas, boleh makan dengan yakin !
terangkan pengetahuan berkaitan DOM dan saya membahagikannya kepada dua bahagian. :
jadi apakah pokok DOM?
Mungkin sesetengah pemula yang telah mempelajari DOM akan sedikit tidak biasa dengan perkataan ini, tetapi sebenarnya, pokok DOM bukanlah sesuatu yang fantasi, sebaliknya, untuk kakitangan hadapan,Pokok DOM ialah pokok yang terdiri daripada elemen HTML halaman yang anda berurusan setiap hari:
Pokok BOM , Setiap nod boleh mempunyai dua identiti: ia boleh menjadi nod anak nod induk, atau ia boleh menjadi nod induk nod anak lain Mari kita perhatikan kod berikut bersama-sama :
Kod di atas,<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>DOM_demo</title> </head> <body> <p> <a href="https://blog.csdn.net/qq_52736131">跳探戈的小龙虾</a> </p> </body> </html>pokok DOM
nya sepatutnya kelihatan seperti ini:
这时候有人要问了,你说这么半天的DOM树,跟操作html元素有关吗? 答案是非常有关,而且只有了解了文档的DOM树结构,才能准确而有效的操作DOM元素,否则会出现各种意料之外的bug。在我们操作一个页面的HTML元素之前,要对整个页面的DOM有一个清晰的绘图,即使在不实实在在绘图,也要在脑中有一个清晰的脉络结构。 关于JavaScript中DOM的一些常见的操作html元素的方法,我又双叒叕分成几个子部分给大家归类介绍: 特别注意第三个,创建属性节点这个方法,要搭配具体的元素,也就是你要先获取某个具体元素element,创建一个属性节点,最后对这个元素添加这个属性节点(setAttributeNode)。 注意,添加节点之前,你要先创建好节点,同时要选好父节点element,第二个方法甚至你还要找好插入位置后面的兄弟节点。 注意,删除时,要找到对应的父节点element才可以顺利删除。 最后是一些常见的DOM属性: 其中,第七个的意思是说把元素内的html代码和文本都转成文本,原先的html代码是执行的,转成文本相当于变成了普通的字符串! 下面我们再讲一讲BOM,由于篇幅有限,BOM不做特别细致的讲解(实用性的确也没有DOM那么大)。我们回顾一下开始的时候关于BOM的介绍: BOM给JavaScript提供用来操作浏览器的若干的"方法" 那么首先我们用一张图把整个BOM的结构给大家梳理一下,与DOM类似,BOM也有一个树状结构: 从上面这张图上,我们可以看到: window是整个BOM树食物链的顶端,因此每一个新打开的窗口,都被认为是一个window对象。 window对象有以下常见的属性和方法: Antaranya, anda boleh melihat bahawa mempunyai fungsi alert(), kerana apabila anda mempelajari JavaScript, input dan output mengalir kebanyakan anda menggunakan tetingkap pop timbul fungsi alert () sebagai demo pertama saya, jadi apabila anda melihat ini, anda mungkin bertanya: Pada masa ituapabila menggunakan fungsi alert() , nampaknya tetingkap itu tidak disebut, maka adakah alert() di sini alert() yang sama yang saya pelajari sebelum ? Jawapannya ialah: Dua alert()s ini sememangnya fungsi yang sama Sebab mengapa tetingkap boleh diabaikan adalah kerana semua sifat dan kaedah window , boleh mempunyai dua kaedah perwakilan : (1) window.property/window.method() (2) direct attribute / Memanggil menggunakan method() bukan sekadar alert(), semua atribut dan fungsi tetingkap di atas adalah sah Rakan-rakan yang berminat boleh mencubanya sendiri. lokasi itu? Objek lokasi ialah atribut objek tetingkap, yang memberikan maklumat tentang dokumen yang dimuatkan dalam tetingkap semasa dan turut menyediakan beberapa fungsi navigasi. Malah, jika kita melihat dengan teliti gambar rajah struktur di atas, kita akan dapati: Objek lokasi bukan sahaja atribut objek tetingkap, tetapi juga atribut objek dokumen . Ini bermakna: tetingkap.lokasi = lokasi = dokumen.lokasi Apakah objek sejarah itu? Objek sejarah ialah atribut objek tetingkap. Ia menyimpan rekod akses Internet pengguna Cap masa rekod ini dikira dari saat tetingkap dibuka. Objek sejarah mempunyai sifat dan kaedah biasa berikut: objek navigasi Objek:
II.II DOM的一些常见的操作元素方法
获取节点的DOM方法
//1.通过元素的id属性值来获取元素,返回的是一个元素对象
var element = document.getElementById(id_content)
//2.通过元素的name属性值来获取元素,返回的是一个元素对象的数组
var element_list = document.getElementsByName(name_content)
//3.通过元素的class属性值来获取元素,返回的是一个元素对象的数组
var element_list = document.getElementsByClassName(class_content)
//4.通过标签名获取元素,返回的是一个元素对象数组
var element_list = document.getElementsByTagName(tagName)
获取/设置元素的属性值的DOM方法
//1.获取元素的属性值,传参自然地是属性名,例如class、id、href
var attr = element.getAttribute(attribute_name)
//2.设置元素的属性值,传参自然地是元素的属性名及要设置的对应的属性值
element.setAttribute(attribute_name,attribute_value)
创建节点(Node)的DOM方法
//1.创建一个html的元素,传参是元素类型,例如p、h1-5、a,下以p为例
var element = document.createElement("p")
//2.创建一个文本节点,传参的是对应的文本内容(注意是文本节点,不是某个html元素)
var text_node = document.createTextNode(text)
//3.创建一个属性节点,传参是对应的属性名
var attr_node = document.createAttribute(attribute_name)
element.setAttributeNode(attr_node)
增添节点的DOM方法
//1.向element内部的最后面添加一个节点,传入的参数是节点类型
element.appendChild(Node)
//2.向element内部某个已存在的节点的前面插入一个节点,仍然传入一个节点类型的参数
element.insertBefore(new_Node,existed_Node)
删除节点的DOM方法
//删除element内的某个节点,传参是节点类型参数
element.removeChild(Node)
DOM常见的一些属性
//1.获取当前元素的父节点
var element_father = element.parentNode
//2.获取当前元素的html元素型子节点
var element_son = element.children
//3.获取当前元素的所有类型子节点,包括html元素、文本和属性
var element_son = element.childNodes
//4.获取当前元素的第一个子节点
var element_first = element.firstChild
//5.获取当前元素的前一个同级元素
var element_pre = element.previousSibling
//6.获取当前元素的后一个同级元素
var element_next = element.nextSibling
//7.获取当前元素的所有文本,包括html源码和文本
var element_innerHTML = element.innerHTML
//8.获取当前元素的所有文本,不包含html源码
var element_innerTEXT = element.innerText
III. BOM及其相关操作
III.I BOM总述
III.II BOM常见对象的介绍
window对象
属性/方法
含义
opener
当前窗口的父窗口
length
窗口中的框架数
document
窗口中当前显示的文档对象
alert(string)
创建一个警告对话框,显示一条信息
close()
关闭窗口
confirm()
创建一个需要用户确认的对话框
open(url,name,[options])
打开一个新窗口并返回新 window 对象
prompt(text,defaultInput)
创建一个对话框要求用户输入信息
setInterval(expression,milliseconds)
经过指定时间间隔计算一个表达式
setInterval(function,millis enconds,[arguments])
经过指定时间间隔后调用一个函数
setTimeout(expression,milli seconds)
在定时器超过后计算一个表达式
setTimeout(expression,milli seconds,[arguments])
在定时器超过时后计算一个函数
objek lokasi
Apakah objek
Objek lokasi mempunyai sifat dan kaedah biasa berikut:
Sifat/Kaedah
属性/方法
内容
host
主机名:端口号
hostname
主机名
href
整个 URL
pathname
路径名
port
端口号
protocol
协议部分
search
查询字符串
reload()
重载当前 URL
repalce()
用新的 URL 替换当前页面
Kandungan
hos
Nama hos: nombor port
nama hos
nama hos
href
Seluruh URL
nama laluan
Nama laluan
port
Nombor port
protokol
Bahagian protokol
cari
Pertanyaan Rentetan
reload()
Muat semula URL semasa
repalce()
Ganti URL semasa dengan yang baharu satu Halaman
objek sejarah
Sifat/Kaedah
属性/方法
描述
length
history 对象中的记录数
back()
前往浏览器历史条目前一个 URL,类似后退
forward()
前往浏览器历史条目下一个 URL,类似前进
go(num)
浏览器在 history 对象中向前或向后
Penerangan
panjang
Bilangan rekod dalam objek sejarah back()Pergi ke URL sebelumnya entri sejarah penyemak imbas, serupa dengan back
forward()
Pergi ke URL seterusnya dalam entri sejarah penyemak imbas, serupa dengan ke hadapan td>
go(num)
Pelayar pergi ke objek sejarah Ke hadapan atau ke belakang
navigator
objek navigator, iaitu atribut tetingkap dalam BOM yang mengenal pasti pelayar klien.
属性
说明
appName
完整的浏览器名称和版本信息
platform
浏览器所在的系统平台
plugins
浏览器中安装的插件信息的数 组
userAgent
浏览器的用户代理字符串
userLanguage
操作系统的默认语言
Beberapa atribut biasa yang berkaitan dengan navigator:
Atribut
Penerangan
appName
Lengkapkan nama penyemak imbas dan maklumat versi
platform
Platform sistem tempat penyemak imbas berada
plugin
Susunan maklumat pemalam yang dipasang dalam penyemak imbas
userAgent
Rentetan ejen pengguna penyemak imbas
userLanguage
Bahasa lalai sistem pengendalian
Jika anda suka, anda boleh menyokongnya tiga kali berturut-turut! ???!
Selain itu, blog ini telah mengambil bahagian dalam[Projek Rising Star], sila sokong ???
! [Cadangan berkaitan: tutorial video javascript]Atas ialah kandungan terperinci Kuasai sepenuhnya perbezaan dan penggunaan DOM dan BOM dalam JavaScript. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!