深入學習Html DOM樹的操作
你對HTML DOM樹的概念是否了解, 這里和大家分享一下,DOM是文檔對象模型(Document Object Model),是基于瀏覽器編程的一套API接口,W3C出臺的推薦標準,每個瀏覽器都有一些細微的差別,單純的 Javascript要結(jié)合DOM才能做DHTML編程,才能做出漂亮的效果、應用于WEB。因此,必須要對DOM有一定的認識,才能把Javascript應用于WEB,或你的RIA應用當中,因為 DHTML本質(zhì)上就是操作DOM樹。
DOM樹
DOM樹的根統(tǒng)一為文檔根—document,DOM既然是樹狀結(jié)構(gòu),那么他們自然有如下的幾種關(guān)系:
◆根結(jié)點(document)
◆父結(jié)點(parentNode)
◆子結(jié)點(childNodes)
兄弟結(jié)點兄弟結(jié)點
(sibling)(sibling)
例子:
假設(shè)網(wǎng)頁的HTML如下
- <html>
- <head>
- <title>never-online'swebsite</title>
- </head>
- <body>
- <div>tutorialofDHTMLandjavascriptprogramming</div>
- </body>
- </html>
我們參照樹的概念,畫出該HTML文檔結(jié)構(gòu)的DOM樹:
html
body head
divt itle
文本 文本
從上面的圖示可以看出html有兩個子結(jié)點,而html就是這兩個子節(jié)點的父結(jié)點,head有節(jié)點title,title下有一個文本節(jié)點,doby下有節(jié)點div,div下有一個文本節(jié)點。
操作DOM樹
開篇已經(jīng)說過,DHTML本質(zhì)就是操作DOM樹。如何操作它呢?假設(shè)我要改變上面HTML文檔中div結(jié)點的文本,如何做?
示例代碼:
- <html>
- <head>
- <title>never-online'swebsite</title>
- <script>
- functionchangedivText(strText){
- varnodeRoot=document;//這個是根結(jié)點
- varnodeHTML=nodeRoot.childNodes[0];//這個是html結(jié)點
- varnodeBody=nodeHTML.childNodes[1];//body結(jié)點
- varnodeDiv=nodeBody.childNodes[0];//DIV結(jié)點
- varnodeText=nodeDiv.childNodes[0];//文本結(jié)點'
- nodeText.data=strText;//文本節(jié)點有data這個屬性,
- 因此我們可以改變這個屬性,也就成功的操作了DOM樹中的一個結(jié)點了
- }
- </script>
- </head>
- <body>
- <div>tutorialofDHTMLandjavascriptprogramming</div>
- <inputonclickinputonclick="changedivText('change?')"
- type="button"value="change"/>
- </body>
- </html>
從上面的示例可以看出,我們可以用上面的這種方法操作DOM樹上的任一節(jié)點。
注:
1.跨域除外,跨域通常是在操作frame上,簡單的說,就是兩個frame不屬于同一域名。
2.上面的操作為了演示,采用的方法是從根結(jié)點一直到文本結(jié)點的遍歷,在DOM方法上,有更簡潔的方法,這些以后會有更多示例加以說明。
【編輯推薦】